H5手機移動端調起瀏覽器(qq瀏覽器,uc瀏覽器)自帶分享功能實例

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);
相關文章
相關標籤/搜索