javascript - vue 动态改微信分享文案的问题
问题描述
现在是这样的 有一个需求 当我在首页分享的时候标题 是 aaaa 当我在详情页分享的时候标题是 bbb 但是页面一加载 文案就定死了 我如何动态改分享的文案 我使用的是vue2 代码如下
我写在main.js中 一开始执行就加载了 一开始定义了 var title = ’aaaa’ desc = ’bbbb’我的做法是 在路由跳转到详情页的时候 title 改变
router.beforeEach(function (to, from, next) { if (to.path.indexOf(’/details’) != -1) { // 当跳转到这个页面时候改变title title = ’cccc’; desc = ’dddd’ } else { title = ’aaaa’; desc = ’bbbb’; }}
但是这样做不行 不知道为什么 从一开始加载 title就永远是 aaa了 除非我在详情页刷新 此时才会重新new vue的实例 才会改变title
分享代码如下:
wx.onMenuShareAppMessage({ // 分享给朋友 title: title, // 我需要动态改这个标题 desc: desc, // 动态改这个描述 link: ’’, // 分享链接 默认以当前链接 imgUrl: imgUrl + ’/static/images/share.png’,// 分享图标 // 用户确认分享后执行的回调函数 success: function () { }); } },
问题解答
回答1:你的微信分享功能的初始化应该是在全局做的。我觉得可以将wx分享封装成一个函数,然后将需要修改的参数暴露成接口,你这里的title。然后在不同的路由(组件)中去完成注册以及配置。
回答2:setPageTitle:function(video){ document.querySelector(’head title’).innerText = video.title; // hack微信等webview中无法修改标题 var iframe = document.createElement(’iframe’); iframe.addEventListener(’load’, function () {setTimeout(function(){document.body.removeChild(iframe)},0) ; }); document.body.appendChild(iframe); // 标题(内容) document.querySelector(’.video_title’).innerText = video.title;},回答3:
推荐一款修改title的组件
相关文章:
1. 为什么我ping不通我的docker容器呢???2. java - 原生CGLib内部方法互相调用时可以代理,但基于CGLib的Spring AOP却代理失效,为什么?3. javascript - js中递归与for循环同时发生的时候,代码的执行顺序是怎样的?4. CSS3可否做出这个效果?5. docker - 如何修改运行中容器的配置6. python - django models 为生成的html元素添加样式。7. html5 - 怎么用npm下载react3版本的路由呢。8. python中怎么对列表以区间进行统计?9. javascript - iframe 为什么加载网页的时候滚动条这样显示?10. css - 移动端 line-height安卓错位,苹果机正常用,缩放解决了,可是又出来了占位的问题
