1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > vue实现当前页面分享其他页面方法

vue实现当前页面分享其他页面方法

时间:2023-11-04 11:49:19

相关推荐

vue实现当前页面分享其他页面方法

web前端|js教程

其他,分享,页面

web前端-js教程

本文主要为大家详细介绍了vue微信分享功能,vue实现当前页面分享其他页面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

图书交换网 源码,内网ubuntu源,tomcat连接池优化,爬虫论文小结,PHP教程 PHP 参考手册,江门全网营销seo推广哪家有名lzw

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

wap企业网站源码,vscode32位怎么卸载,ubuntu日志文件,tomcat8.5配置优化,sqlite.orm,盐城网页设计,免费 网站 服务器,手机端自适应幻灯片插件,前端框架学习路线,地底爬虫森,php进阶书籍,温州seo团队,架构师springboot,phpcms网站被黑,手机网页隐藏滚动条,织梦模板制作教程,供求信息后台模板,android 页面整体滚动,java银行业务管理系统,书法网站程序lzw

首先以分享给朋友为例

个人主页源码带后台,vscode 克隆代码慢,ubuntu 依赖项,手机网站tomcat,sqlite查找第三行数据,fython爬虫,PHP空间申请信用卡,山东seo优化专业定制,微赞网站安装教程,聚合页模板lzw

1、先看官方文档

wx.onMenuShareAppMessage({ title: \, // 分享标题 desc: \, // 分享描述 link: \, // 分享链接,该链接域名或路径必须与当前页面对应的公众号JS安全域名一致 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、shareOut()函数

let signStr = \;//sha1加密字符串let timestamp = 1473254558; //时间戳let nonceStr = shupao;var obj = { title:"", //标题 desc:"文字描述",//描述 link:"/wx/pub/sr/simpleRegister.do", imgUrl:"/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、而且我们要在当前页面分享出去之后 , 其他用户打开之后 不是当前分享出去的页面 ,这就需要 调整 shareOut()函数中 obj对象中的 link参数为其他页面链接

6、link参数

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

Vue.js中常用指令有哪些

Vue.js 自定义指令方法

vue如何使用全局变量

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。