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

2021-08-06  本文已影响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("失败")
            }
        });
    });
}
上一篇下一篇

猜你喜欢

热点阅读