共计 1540 个字符,预计需要花费 4 分钟才能阅读完成。
H5 页面在微信端的分享
微信分享,咋一看好像很复杂,实则非常简单。只需要调用微信官方出的微信 jssdk,加上些许配置,就可以实现 h5 页面在微信上的分享,官方文档地址为:https://mp.weixin.qq.com/wiki…
一、获取基本信息
找到已有公众号的 appid,根据这个 appid 和 url 向后端发起请求,拿到配置所需要的参数:timestamp、noncestr 和 signature。
二、实现
1、页面引入 JS-SDK 文件
通过 script 标签,引入微信官网的 JS-SDK 文件 <script src=”https://res.wx.qq.com/open/js/jweixin-1.2.0.js” type=”text/javascript”></script>
2、基本配置
wx.config({
debug: false, // 是否开启调试模式
appId: appid, //appid
timestamp: timestamp, // 时间戳
nonceStr: noncestr, // 随机字符串
signature: signature, // 签名
jsApiList: [
‘onMenuShareTimeline’,
‘onMenuShareAppMessage’,
‘onMenuShareQQ’,
‘onMenuShareWeibo’,
‘onMenuShareQZone’
] // 需要使用的 JS 接口列表
})
3、使用
wx.ready(function(){
// 分享给好友
wx.onMenuShareAppMessage({
title: title, // 分享标题
desc: desc, // 分享描述
link: link, // 分享链接
imgUrl: imgUrl, // 分享图标
success: function () {
doShareDone()
},
cancel: function () {
doShareCancel()
}
})
// 分享到朋友圈
wx.onMenuShareTimeline({
title: title, // 分享标题
link: link, // 分享链接
imgUrl: imgUrl, // 分享图标
success: function () {
doShareDone()
},
cancel: function () {
doShareCancel()
}
})
})
// 分享成功回调
function doShareDone () {
console.log(‘ 分享成功 ’)
}
// 取消分享回调
function doShareCancel () {
console.log(‘ 取消了分享 ’)
}
三、调试
wx.config 里的 debug 字段设置为 true 时,就可以进行调试。
调试要用到微信开发者工具,选择公众号网页项目,输入页面地址就可以了。
四、遇到的问题及解决方案
微信 JS-SDK 说明文档的附录 5 里有大部分问题的解决方案,在这里我列出我遇到的几个上面没有给出解决方案的。
1、Uncaught TypeError: Cannot read property ‘config’ of undefined
解决:html 页面单独引入了 sdk,并且组件统一也引入了一遍 sdk,导致问题,删除其中之一。
2、Uncaught (in promise) TypeError: Cannot read property ‘ready’ of undefined
解决:同问题 1。
3、invalid signature
解决:如果文档里的方法都没有解决这个问题,还有一种方法,先设置一种最基础的配置,使其 config ok,然后再设置一遍自己需要的有各种参数的分享文案,这样能绕过配置,成功分享。说的可能有点拗口,简单点理解就是,页面只要有一个 config 成功的配置,就可以再继续配置其它分享,哪怕这个分享配置的 signature 无效。