1.使用第三方包,引入微信的JS_SDK
安装:npm i weixin-js-sdk --save
2.封装一个公共方法
/* eslint-disable*/
import wx from 'weixin-js-sdk' //微信sdk依赖
const jsApiList = ['onMenuShareAppMessage', 'onMenuShareTimeline', 'onMenuShareQQ', 'onMenuShareWeibo']
//要用到微信API
function getJSSDK (data, dataForWeixin) {
wx.config({
debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: data.appId, // 必填,公众号的唯一标识
timestamp: data.timestamp, // 必填,生成签名的时间戳
nonceStr: data.noncestr, // 必填,生成签名的随机串
signature: data.signature, // 必填,签名
jsApiList: jsApiList, // 必填,需要使用的JS接口列表
success: () => {
alert('success')
},
})
wx.ready(function () {
wx.onMenuShareAppMessage({
title: dataForWeixin.title,
desc: dataForWeixin.desc,
link: dataForWeixin.linkurl,
imgUrl: dataForWeixin.img,
trigger: function trigger (res) { },
success: function success (res) {
// alert('已分享');
},
cancel: function cancel (res) {
// alert('已取消');
},
fail: function fail (res) {
// alert('进来了');
}
});
// 2.2 监听“分享到朋友圈”按钮点击、自定义分享内容及分享结果接口
wx.onMenuShareTimeline({
title: dataForWeixin.title,
link: dataForWeixin.linkurl,
imgUrl: dataForWeixin.img,
trigger: function trigger (res) {
// alert('用户点击分享到朋友圈');
},
success: function success (res) {
// alert('已分享');
},
cancel: function cancel (res) {
//alert('已取消');
},
fail: function fail (res) {
// alert(JSON.stringify(res));
}
});
// 2.3 监听“分享到QQ”按钮点击、自定义分享内容及分享结果接口
wx.onMenuShareQQ({
title: dataForWeixin.title,
desc: dataForWeixin.desc,
link: dataForWeixin.linkurl,
imgUrl: dataForWeixin.img,
trigger: function trigger (res) {
//alert('用户点击分享到QQ');
},
complete: function complete (res) {
// alert(JSON.stringify(res));
},
success: function success (res) {
//alert('已分享');
},
cancel: function cancel (res) {
//alert('已取消');
},
fail: function fail (res) {
//alert(JSON.stringify(res));
}
});
// 2.4 监听“分享到微博”按钮点击、自定义分享内容及分享结果接口
wx.onMenuShareWeibo({
title: dataForWeixin.title,
desc: dataForWeixin.desc,
link: dataForWeixin.linkurl,
imgUrl: dataForWeixin.img,
trigger: function trigger (res) {
//alert('用户点击分享到微博');
},
complete: function complete (res) {
// alert(JSON.stringify(res));
},
success: function success (res) {
//alert('已分享');
},
cancel: function cancel (res) {
// alert('已取消');
},
fail: function fail (res) {
// alert(JSON.stringify(res));
// console.log(JSON.stringify(res));
}
});
})
wx.error((res) => {
console.log(JSON.stringify(res) + "微信验证失败");
});
}
export default getJSSDK
3、页面中的使用
// 引入wxShare
/*
dataForWeixin的数据格式
{
title // 分享的标题
desc // 描述或者介绍
link // 分享的页面路基
imgUrl // 分享的缩率图
}
data的数据格式
{
appId //公众号的唯一标识appid
timestamp //生成签名的时间戳
nonceStr // 生成签名的随机串
signature //签名
}
*/
export default{
methods:{
wxShare.getJSSDK(data, dataForWeixin)
}
}
注意:H5页小程序分享