本文针对微信jssdk用法进行了详细汇总,分享给大家,供大家参考,具体内容如下
1.绑定域名
2.引入js文件
在需要调用JS接口的页面引入如下JS文件,(支持https):页面启用了https,务必引入3.通过config接口注入权限验证配置
这一步是通过用当前的url向后台发请求拿到一系列参数。即后台会拿我的url去向微信进行认证。这里需要注意的事用于验证的当前的url写法,务必写成以上形势。否则会在进行config时报invalid signature,
确认url是页面完整的url(请在当前页面alert(location.href.split('#')[0])确认),包括'http(s)://'部分,以及'?'后面的GET参数部分,但不包括'#'hash后面的部分。
确保你获取用来签名的url是动态获取的,动态页面可参见实例代码中PHP的实现方式。如果是html的静态页面在前端通过ajax将url传到后台签名,前端需要用js获取当前页面除去'#'hash部分的链接(可用location.href.split('#')[0]获取,而且需要encodeURIComponent),因为页面一旦分享,微信客户端会在你的链接末尾加入其它参数,如果不是动态获取当前链接,将导致分享后的页面签名失败。
注意这里的动态,不要随便自己拼接,同时encodeURIComponent。
{
wx.config({
debug: true,// 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: '',// 必填,公众号的唯一标识
timestamp:,// 必填,生成签名的时间戳
nonceStr: '',// 必填,生成签名的随机串
signature: '',// 必填,签名,见附录1
jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
})
4.通过ready接口处理成功验证
config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
<div class="jb51code">
<pre class="brush:js;">
wx.ready (()=> {
// alert('ready');
//$('#onMenuShareAppMessage').on('click',()=> {
// 分享给朋友
wx.onMenuShareAppMessage({
title: '',desc: '',link: shareUrl,imgUrl: '',trigger: function (res) {
// alert('用户点击发送给朋友');
},success: function (res) {
alert('已分享');
},cancel: function (res) {
alert('已取消');
},fail: function (res) {
alert(JSON.stringify(res));
}
});
//});
//分享到朋友圈
wx.onMenuShareTimeline({
title: '',// 分享标题
link: shareUrl,// 分享链接
imgUrl: '',// 分享图标
success: function () {
alert('已分享');
// alert($('.no-num').html());
},cancel: function () {
alert('已取消');
// 用户取消分享后执行的回调函数
// alert('取消');
}
});
});
<pre class="brush:js;">
wx.ready (()=> {
// alert('ready');
//$('#onMenuShareAppMessage').on('click',()=> {
// 分享给朋友
wx.onMenuShareAppMessage({
title: '',desc: '',link: shareUrl,imgUrl: '',trigger: function (res) {
// alert('用户点击发送给朋友');
},success: function (res) {
alert('已分享');
},cancel: function (res) {
alert('已取消');
},fail: function (res) {
alert(JSON.stringify(res));
}
});
//});
//分享到朋友圈
wx.onMenuShareTimeline({
title: '',// 分享标题
link: shareUrl,// 分享链接
imgUrl: '',// 分享图标
success: function () {
alert('已分享');
// alert($('.no-num').html());
},cancel: function () {
alert('已取消');
// 用户取消分享后执行的回调函数
// alert('取消');
}
});
});