今天碰到了微信分享的需求,整体上来说仍是比较简单的,可是仍是碰到了一个假想的坑(真的是假想),😇
api地址
1.绑定域名,在公众号后台绑定域名,因此最后的测试必定要是线上(环境要么用内网穿透,这样容易调试,不用每一次都发测试环境)html
2.在index.html文件里面引入vue
http://res.wx.qq.com/open/js/jweixin-1.4.0.js // 注意协议
3.经过config接口注入权限验证配置, 下面五个参数都是经过请求后台,后台返回给你的。 注意: 当前页面的url是要在这个接口里给后台的,它们才能生成可用的, 签名算发, url的格式以下: url(当前网页的URL,不包含#及其后面部分),因此要注意vue-router的模式(经过config接口注入权限验证配置,jsApiList是调用的事件,api文档附录2里面有)git
wx.config({ debug: false, // 是否开启调试模式 appId: appId, //appid timestamp: timestamp, // 时间戳 nonceStr: nonceStr, // 随机字符串,只有这个是驼峰🎃 signature: signature, // 签名 jsApiList: [ "onMenuShareTimeline", "onMenuShareAppMessage", "onMenuShareQQ", "onMenuShareWeibo", "onMenuShareQZone" ] // 须要使用的JS接口列表 }); // 判断当前客户端版本是否支持指定JS接口 ,这步可无 wx.checkJsApi({ jsApiList: [ "onMenuShareTimeline", "onMenuShareAppMessage", "onMenuShareQQ", "onMenuShareWeibo", "onMenuShareQZone" ], // 须要检测的JS接口列表,全部JS接口列表见附录2, success: function(res) { console.log(res); // 以键值对的形式返回,可用的api值true,不可用为false // 如:{"checkResult":{"chooseImage":true},"errMsg":"checkJsApi:ok"} } });  // 经过ready接口处理成功验证 wx.ready(function() { const share = { title: mainTitle, // 分享出去的title desc: subTitle, // 描述信息 imgUrl: smallIcons, // 分享的小图标 link: url, // 分享的除去的url success: function() { dosometing(); // 分享成功,成功以后要作的事情 }, cancel: function() { dosometing(); // 分享取消,取消以后要作的事情 } }; wx.onMenuShareAppMessage(share); // 微信好友 wx.onMenuShareTimeline(share); // 朋友圈 wx.onMenuShareQQ(share); // QQ wx.onMenuShareQZone(share); // QQ空间 wx.onMenuShareWeibo(share); // 腾讯微博 }); // 若是失败 , 获取失败信息 wx.error(function(res) { console.log("错误", res); });
我看别人的分享,点击分享都是有如上一个引导图的(觉得是官网自带的),可是我作好没有引导图,我开始一只觉得我那一步出问题了,后来我发现,这个图是要本身加的,点击分享,打开这个蒙层,在成功回调里面,把这个蒙层去掉。😅github
blog:https://hericium.github.io/20...vue-router