vue微信分享 vue实现当前页面分享其他页面

网友投稿 566 2023-03-09


vue微信分享 vue实现当前页面分享其他页面

本文实例为大家分享了vue微信分享展示的具体代码,供大家参考,具体内容如下

首先以分享给朋友为例

1、先看官方文档

wx.onMenuShareAppMessage({

title: '', // 分享标题

desc: '', // 分享描述

imgUrl: '', // 分享图标

type: '', // 分享类型,music、video或link,不填默认为link

dataUrl: '', // 如果type是music或video,则要提供数据链接,默认为空

success: function () {

// 用户确认分享后执行的回调函数

},

cancel: function () {

// 用户取消分享后执行的回调函数

}

});

2、vue分享踩的坑

* 1、微信分享中获取动态的url

* 2、 微信二次分享自动添加的参数     form=singlemessage

* 3、vue中各个页面都可以调用分享

3、直接代码分析

为了保证每个页面都可以调起微信分享,需要在vue根组件中,添加 watch监听

代码

watch: {

// 监听 $route 变化调用分享链接

"$route"(to, from) {

let currentRouter = this.$router.currentRoute.fullPath;

if(currentRouter.indexOf('userShare') == -1){

//如果不是userShare分享页面,则分享另外一个接口

this.shareOut();

}else{

this.shareOutTwo();

//当前页面是userShare页面时分享调用另外一个接口

}

}

},

4、sharPsejAlcpuXeOut()函数

let signStr = ''; //sha1加密字符串

let timestamp = 1473254558; //时间戳

let nonceStr = 'shupao';

var obj = {

title:"", //标题

desc:"文字描述", //描述

link:"http://XXXXXX.com/wx/pub/sr/simpleRegister.do",

imgUrl:"http://XXXXXXXXX.com/picactive.jpg"

};

this.$ydkAjax({

SENTYPE: "GET",

url: this.$domain + '/wx/pub/common/getJsApiTicket.json', //自己服务器获取jsapi_ticket接口

params: null,

successFc: (response) => {

//拼接sha1加密字符串

signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '&timestamp=' + timestamp + '&url=' + window.location.href;

var signature = SHA1(signStr);

wx.config({

debug: false,

appId: "wx6957b3a945a05e90", //appId

timestamp: timestamp, //时间戳

nonceStr: nonceStr, //加密需要字符串(自己定义的)

signature: signature, //sha1加密后字符串

jsApiList: [ 'onMenuShareTimeline', 'onMenuShareAppMessage']

});

wx.ready(function () {

//分享到朋友圈"

wx.onMenuShareTimeline({

title: obj.title,

link: obj.link, // 分享链接

imgUrl: obj.imgUrl, // 分享图标

success: function () {

// console.log('分享到朋友圈成功')

},

cancel: function () {

// console.log('分享到朋友圈失败')

}

});

//分享给朋友

wx.onMenuShareAppMessage({

title: obj.title, // 分享标题

desc: obj.desc, // 分享描述

link: obj.link, // 分享链接

imgUrl: obj.imgUrl, // 分享图标

success: function () {

// console.log('分享到朋友成功')

},

cancel: function () {

// console.log('分享到朋友失败')

}

});

})

},

isLayer: false

})

5、需要注意的事

*1、url是直接通过 window.location.href 获取的,不是使用 window.location.href.split(“#”)[0]来获取, 因为我的vue项目是通过hash模式来进行路由跳转的 , 直接使用 window.location.href.split(“#”)[0]会导致签名失败

//拼接sha1加密字符串

signStr = 'jsapi_ticket=' + response.data.data + '&noncestr=' + nonceStr + '&timestamp=' + timestamp + '&url=' + window.location.href

*2、而且我们要在当前页面分享出去之后 , 其他用户打开之后 PsejAlcpuX不是当前分享出去的页面 ,这就需要 调整 shareOut()函数中 objhttp://对象中的 link参数为其他页面链接

6、link参数

上述 5 问题中的加密字符串汇总的 url 和 分享对象中 link中的页面链接可以不用保持一样,因为本来就是要在当前页面分享出去其他页面的链接。网上我看到有人说这两个必须要保持一样,其实没有必要, 除非你只是简单的在vue项目中的其中一个页面做分享 , 然后只分享当前页面才需要让二者保持一致性。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:React Native 使用Fetch发送网络请求的示例代码
下一篇:23种设计模式(13)java观察者模式
相关文章

 发表评论

暂时没有评论,来抢沙发吧~