H5手機移動端調起瀏覽器(qq瀏覽器,uc瀏覽器)自帶分享功能實例css
(轉載:https://blog.csdn.net/weixin_38787928/article/details/86741227)html
html:html5
<span class="viewshare wx" data-mshare="2"></span> <span class="viewshare wxline" data-mshare="1"></span> <span class="viewshare QQ" data-mshare="3"></span> <span class="viewshare wb" data-mshare="4"></span>
js:android
// 引入JS文件 <script src="js/mshare.js"></script> var u = navigator.appVersion; var uc = u.split('UCBrowser/').length > 1 ? 1 : 0; var qq = u.split('MQQBrowser/').length > 1 ? 2 : 0; var wx = ((u.match(/MicroMessenger/i)) && (u.match(/MicroMessenger/i).toString().toLowerCase() == 'micromessenger')); // 綁定單擊事件 $('.wx,.wxline,.QQ,.wb').on("click", function () { if(uc||(qq && !wx)){ mshare.init(+$(this).data('mshare')); } }
mshare.jsios
/** * mshare.js * 此插件主要做用是在UC和QQ兩個主流瀏覽器 * 上面觸發微信分享到朋友圈或發送給朋友的功能 * 代碼編寫過程當中 參考: * http://mjs.sinaimg.cn/wap/module/share/201501261608/js/addShare.js * 此外,JefferyWang的項目對我也有必定啓示: * https://github.com/JefferyWang/nativeShare.js * */ !(function(global) { 'use strict'; var UA, uc, qq, wx, tc, qqVs, ucVs, os,qqBridgeDone; UA = navigator.appVersion; // 是不是 UC 瀏覽器 uc = UA.split('UCBrowser/').length > 1 ? 1 : 0; // 判斷 qq 瀏覽器 // 然而qq瀏覽器分高低版本 2表明高版本 1表明低版本 qq = UA.split('MQQBrowser/').length > 1 ? 2 : 0; // 是不是微信 wx = ((UA.match(/MicroMessenger/i)) && (UA.match(/MicroMessenger/i).toString().toLowerCase() == 'micromessenger')); // 瀏覽器版本 qqVs = qq ? parseFloat(UA.split('MQQBrowser/')[1]) : 0; ucVs = uc ? parseFloat(UA.split('UCBrowser/')[1]) : 0; //獲取操做系統信息 iPhone(1) Android(2) os = (function () { var ua = navigator.userAgent; if (/iphone|ipod/i.test(ua)) { return 1; } else if(/android/i.test(ua)){ return 2; } else { return 0; } }()); // qq瀏覽器下面 是否加載好了相應的api文件 qqBridgeDone = false; // 進一步細化版本和平臺判斷 // 參考: https://github.com/JefferyWang/nativeShare.js // http://mjs.sinaimg.cn/wap/module/share/201501261608/js/addShare.js if ((qq && qqVs < 5.4 && os == 1) || (qq && qqVs < 5.3 && os == 1)) { qq = 0; } else { if (qq && qqVs < 5.4 && os == 2) { qq = 1; } else { if (uc && ( (ucVs < 10.2 && os == 1) || (ucVs < 9.7 && os == 2) )) { uc = 0; } } } /** * qq瀏覽器下面 根據不一樣版本 加載對應的bridge * @method loadqqApi * @param {Function} cb 回調函數 */ function loadqqApi(cb) { if (!qq) { // qq == 0 return cb && cb(); } var qqApiScript = document.createElement('script'); //須要等加載過qq的接口文檔以後,再去初始化分享組件 qqApiScript.onload = function () {cb && cb();}; qqApiScript.onerror = function () {}; // qq == 1 低版本 // qq == 2 高版本 qqApiScript.src = (qq == 1 ) ? 'http://3gimg.qq.com/html5/js/qb.js' : 'http://jsapi.qq.com/get?api=app.share'; document.body.appendChild(qqApiScript); } /** * UC瀏覽器分享 * @method ucShare */ function ucShare(config) { // ['title', 'content', 'url', 'platform', 'disablePlatform', 'source', 'htmlID'] // 關於platform // ios: kWeixin || kWeixinFriend; // android: WechatFriends || WechatTimeline // uc 分享會直接使用截圖 var platform = '', shareInfo; // 指定了分享類型 if (config.type) { if (os == 2) { if(config.type==1){ platform = 'WechatTimeline'; }else if(config.type==2){ platform = 'WechatFriends'; }else if(config.type==3){ platform = 'QQ'; }else if(config.type==4){ platform = 'SinaWeibo'; }else if(config.type==0){ platform = 'undefined'; } } else if (os == 1) { if(config.type==1){ platform = 'kWeixinFriend'; }else if(config.type==2){ platform = 'kWeixin'; }else if(config.type==3){ platform = 'kQQ'; }else if(config.type==4){ platform = 'kSinaWeibo'; }else if(config.type==0){ platform = 'undefined'; } } } shareInfo = [ config.title, config.desc, config.url, platform, '', '', '' ]; // android if (window.ucweb) { ucweb.startRequest && ucweb.startRequest('shell.page_share', shareInfo); } // ios else if (window.ucbrowser) { ucbrowser.web_share && ucbrowser.web_share.apply(null, shareInfo); } }; /** * qq瀏覽器分享函數 * @method qqShare */ function qqShare(config) { var type = ''; //微信好友1, 微信朋友圈8,QQ 4 if(config.type==1){ type = 8; }else if(config.type==2){ type = 1; }else if(config.type==3){ type = 4; }else if(config.type==4){ type = 11; }else if(config.type==0){ type = 'undefined'; } var share = function () { var shareInfo = { 'url': config.url, 'title': config.title, 'description': config.desc, 'img_url': config.img, 'img_title': config.title, 'to_app': type, 'cus_txt': '' }; if (window.browser) { browser.app && browser.app.share(shareInfo); } else if (window.qb) { qb.share && qb.share(shareInfo); } }; if (qqBridgeDone) { share(); } else { loadqqApi(share); } }; /** * 對外暴露的接口函數 * @method mShare * @param {Object} config 配置對象 參數見示例 * var config = { * title : 'Lorem ipsum dolor sit.' * , url : 'http://m.ly.com' * , desc : 'Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quaerat inventore minima voluptates.' * , img : 'http://img1.40017.cn/cn/s/c/2015/loading.gif' * , type : type // 1 ==> 朋友圈 2 ==> 朋友 0 ==> 直接彈出原生 3==>QQ * } */ function mShare(config) { this.check = function (succssFn, wxFn, failFn) { if (uc) { succssFn(); } else if (qq && !wx) { succssFn(); } else if (wx) { wxFn(); } else { failFn(); } } this.config = config; this.init = function (type) { if (typeof type != 'undefined') this.config.type = type; try { if (uc) { ucShare(this.config); } else if (qq && !wx) { qqShare(this.config); } } catch (e) {} } } // 預加載 qq bridge loadqqApi(function () { qqBridgeDone = true; }); // 方法暴露給全局變量 global.mShare = mShare; })(this);