最近公司要做一个微信分享的功能,现在已经完成了基本的开发工作,现在想把js接口在进行封装,更简单。现在放到window.onload,自己定义就无效了
var appId="";
var timestamp="";
var nonceStr="";
var signature="";
var weixinTitle = "";
var weixinLink = "";
var weixinImageUrl = "";
var weixinDesc = "";
var data1 = {};
function weixinC(){
function config(configObj){
data1['url'] = configObj.url;
weixinTitle = configObj.title;
weixinLink = configObj.link;
weixinImageUrl = configObj.imageUrl;
weixinDesc = configObj.desc;
}
return {
config:config
}
}
var weixinShareUrl = weixinC();
//当前页面路径 标题 链接 图片链接 内容
function WeiXinShare(){
$.ajax({
"url": ctx+'/weixin/weixinShare',
"type": "POST",
"dataType": "json",
"data": data1,
async:true,
success: function(result) {
//var obj = JSON.parse(result.toString());
appId = result.data.appId;
timestamp = result.data.timestamp;
nonceStr = result.data.nonceStr;
signature = result.data.signature;
}
});
}
window.onload = function (){
WeiXinShare();
wx.config({
debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: appId, // 必填,公众号的唯一标识
timestamp: timestamp, // 必填,生成签名的时间戳
nonceStr: nonceStr, // 必填,生成签名的随机串
signature: signature,// 必填,签名,见附录1
jsApiList: ['onMenuShareTimeline','onMenuShareAppMessage'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
//config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。
//获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
wx.ready(function(){
//获取“分享到朋友圈”按钮点击状态及自定义分享内容接口
wx.onMenuShareTimeline({
title: weixinTitle, // 分享标题
desc: weixinDesc, // 分享描述
link: weixinLink, // 分享链接
imgUrl: weixinImageUrl, // 分享图标
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
//获取“分享给朋友”按钮点击状态及自定义分享内容接口
wx.onMenuShareAppMessage({
title: weixinTitle, // 分享标题
desc: weixinDesc, // 分享描述
link: weixinLink, // 分享链接
imgUrl: weixinImageUrl, // 分享图标
type: '', // 分享类型,music、video或link,不填默认为link
dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空
success: function () {
// 用户确认分享后执行的回调函数
},
cancel: function () {
// 用户取消分享后执行的回调函数
}
});
});
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。
wx.error(function(res){
alert("分享失败");
});
}
//初始化数据
weixinShareUrl.config({
url:"http://www.abazc.com/hpzc-mobile/mtrade/accountCenter",
title:"4324324",
link:"http://www.baidu.com/",
imageUrl:"",
desc:"123123"
})
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
业精于勤,荒于嬉;行成于思,毁于随。