美文网首页
微信浏览器自定义分享功能

微信浏览器自定义分享功能

作者: 秀萝卜 | 来源:发表于2021-08-06 09:12 被阅读0次

    一、使用JSSDK需要一个公众号(需要认证!):

    (1)、把自己项目的服务器地址输入。

    (2)、把MP_verify_m7Qp93BAuIGDWRVO.txt 文件下载下来,放到该服务器域名指向的根目录!

    • 这样基础工作就完成了!*
    image

    ** 二、后台生成前端需要的参数!**

    (1)、前端想要实现分享、扫一扫等等需要的参数!

    wx.config({
            debug: false,//是否开启调试功能,这里关闭!
            appId: jssdk.appId,//appid
            timestamp: parseInt(jssdk.timestamp), //时间戳
            nonceStr: jssdk.nonceStr, //生成签名的随机字符串
            signature: jssdk.signature,//签名
            jsApiList: [
                "onMenuShareTimeline",
                "onMenuShareAppMessage"
            ]
        });
    

    (2)、后端代码获取参数实现如下:

    http://demo.open.weixin.qq.com/jssdk/sample.zip

    三、前端代码封装实现:

    (一)、页面中引入!

      **<script src='https://res.wx.qq.com/open/js/jweixin-1.0.0.js'></script>**
    

    (二)、请求后台的接口,获取步骤二中展示的需要的参数,然后调用如下的封装的函数即可实现自定义分享,扫一扫、拍照等功能!

    /**
     * @param {jssdk为从后台请求过来的各种信息,包括appId,timestamp,nonceStr,signature} jssdk 
     * 以上4个参数,需要后台在公众号相关平台进行配置,然后得出!前端页面必须放在服务号配置的域名下面才可以保证成功!
     * @param {为js对象格式,options里面包含自定义的title,desc,link,imgUrl} options 
     * 引入jweixin文件后,直接调用该函数,即可实现自定义分享功能
     */
    
    
    function shareJs(jssdk, options) {
        wx.config({
            debug: false,//是否开启调试功能,这里关闭!
            appId: jssdk.appId,//appid
            timestamp: parseInt(jssdk.timestamp), //时间戳
            nonceStr: jssdk.nonceStr, //生成签名的随机字符串
            signature: jssdk.signature,//签名
            jsApiList: [
                "onMenuShareTimeline",
                "onMenuShareAppMessage"
            ]
        });
        var defaults = {
            title: "分享的标题",
            desc: "分享的描述",
            link: location.href, //分享页面地址,不能为空,这里可以传递参数!!!!!!!
            imgUrl: 'https://tup.iheima.com/sport.png', //分享是封面图片,不能为空
            success: function () { }, //分享成功触发
            cancel: function () { } //分享取消触发,需要时可以调用
        }
        // 合并对象,后面的替代前面的!
        options = Object.assign({}, defaults, options);
        wx.ready(function () {
            var thatopts = options;
            // 分享到朋友圈
            wx.onMenuShareTimeline({
                title: thatopts.title, // 分享标题
                desc: thatopts.desc, // 分享描述
                link: thatopts.link, // 分享链接
                imgUrl: thatopts.imgUrl, // 分享图标
                success: function () {
                    // alert("成功");
                },
                cancel: function () {
                    // alert("失败")
                }
            });
            // 分享给朋友
            wx.onMenuShareAppMessage({
                title: thatopts.title, // 分享标题
                desc: thatopts.desc, // 分享描述
                link: thatopts.link, // 分享链接
                imgUrl: thatopts.imgUrl, // 分享图标
                success: function () {
                    // alert("成功");
                },
                cancel: function () {
                    // alert("失败")
                }
            });
        });
    }
    

    相关文章

      网友评论

          本文标题:微信浏览器自定义分享功能

          本文链接:https://www.haomeiwen.com/subject/logmvltx.html