之前写过一篇使用微信JS-SDK来实现扫一扫功能的博客
微信公众号开发–微信JS-SDK扫一扫功能
在该博客里介绍了微信JS-SDK的基本用法,其中包括以下几个步骤
还详细介绍了通过config接口注入权限验证配置以及签名算法实现的Java版本
前两天在做微信分享的时候发现按照以前的思路每次都不能正确获取“分享到朋友圈”按钮点击状态及自定义分享内容接口,而是必须通过一个按钮先点击帮点事件,然后才能获取“分享到朋友圈”按钮点击状态及自定义分享内容接口。
回顾一下以前扫一扫的js代码
下面是wx.config的主代码
<script type="text/javascript">
$(function() {
var timestamp = $("#timestamp").val();
var nonceStr = $("#noncestr").val();
var signature = $("#signature").val();
wx.config({
debug : true,
appId : 'wx622ca8545e5c354b',
timestamp : timestamp,
nonceStr : nonceStr,
signature : signature,
jsApiList : [ 'scanQRCode' ]
});
});
</script>
下面是扫一扫的代码
前提是有一个
<button id="scanQRCode">扫码</button>
$("#scanQRCode").click(function() {
wx.scanQRCode({
needResult : 1,
desc : 'scanQRCode desc',
success : function(res) {
var url = res.resultStr;
if(url.indexOf(",")>=0){
var tempArray = url.split(',');
var tempNum = tempArray[1];
$("#id_securityCode_input").val(tempNum);
}else{
$("#id_securityCode_input").val(url);
}
}
});
});
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
以上代码完全没有问题,但是当我配置获取“分享到朋友圈”按钮点击状态及自定义分享内容接口的时候却始终不能成功
解决方案
原来是wx.config执行需要时间,而我们把扫一扫放在外面完全没影响。是因为,我们点击扫码的时候wx.config已经加载好了,而我之前的点击一下再分享和扫码是一个道理,为了不让用户点击一下再分享需要将我上面讲的微信JS-SDK使用步骤中的第四步用到
下面是官方的解释
步骤四:通过ready接口处理成功验证
wx.ready(function(){
// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
});
上面的描述给出了我之前的扫码可以成功而分享不能成功的合理解释。
像点击扫码这样的事件属于
对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
而对于分享事件属于
如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行
下面就来看一下正确的获取“分享到朋友圈”按钮点击状态及自定义分享内容接口的使用方法
<script type="text/javascript">
$(function() {
var timestamp = $("#timestamp").val();
var nonceStr = $("#noncestr").val();
var signature = $("#signature").val();
wx.config({
debug : true,
appId : 'wx622ca8545e5c354b',
timestamp : timestamp,
nonceStr : nonceStr,
signature : signature,
jsApiList : [ 'scanQRCode','onMenuShareAppMessage' ]
});
wx.ready(function(){
wx.onMenuShareAppMessage({
title: '这是一个测试的标题',
desc: '这个是分享奥朋友圈的描述信息',
link: 'http://www.baidu.com',
imgUrl: 'https://www.baidu.com/img/bd_logo1.png',
trigger: function (res) {
},
success: function (res) {
alert('分享成功');
},
cancel: function (res) {
alert('你没有分享');
},
fail: function (res) {
alert(JSON.stringify(res));
}
});
});
});
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
完整的分享到朋友圈和朋友的js代码
<script type="text/javascript">
$(function() {
var timestamp = $("#timestamp").val();
var nonceStr = $("#noncestr").val();
var signature = $("#signature").val();
wx.config({
debug : false,
appId : 'wx622ca8545e5c354b',
timestamp : timestamp,
nonceStr : nonceStr,
signature : signature,
jsApiList : [ 'scanQRCode','onMenuShareAppMessage','onMenuShareTimeline' ]
});
wx.ready(function(){
wx.onMenuShareTimeline({
title: '这是一个测试的标题--程高伟的博客',
link: 'http://blog.csdn.net/frankcheng5143',
imgUrl: 'http://avatar.csdn.net/E/B/6/1_frankcheng5143.jpg',
success: function () {
alert('分享到朋友圈成功');
},
cancel: function () {
alert('你没有分享到朋友圈');
}
});
wx.onMenuShareAppMessage({
title: '这是一个测试的标题--百度',
desc: '这个是要分享内容的一些描述--百度一下,你就知道',
link: 'http://www.baidu.com',
imgUrl: 'https://www.baidu.com/img/bd_logo1.png',
trigger: function (res) {
},
success: function (res) {
alert('分享给朋友成功');
},
cancel: function (res) {
alert('你没有分享给朋友');
},
fail: function (res) {
alert(JSON.stringify(res));
}
});
});
});
</script>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
关于绑定域名和签名算法参考
微信公众号开发–微信JS-SDK扫一扫功能
效果
通过菜单进入页面
进入后呈现的页面
点击发送给朋友
出现我们在js中设置的分享内容
分享成功执行的方法
分享成功的页面
用户点击取消,没有分享时的方法
分享到朋友圈的页面
分享成功和没有分享和上面的效果一样
参考文献
微信JS-SDK说明文档
微信公众号开发–微信JS-SDK扫一扫功能