表示是第一次使用vue做单应用显目,也是在逐渐的摸索中~更是各种踩坑,各种填坑,打算写博客么?是因为不想写笔记了,嗯嗯 就是这么简单 进入正题。刚开始做微信分享的这个功能的时候,脑补了官方文档微信JS-SDK说明文档微信JS-SDK基础的知识不多说了,反正多看文档总是没错的~在安卓系统上面分享是没出错的,但是在ios上面问题就来了,表示无限吐槽ios,但是吐槽归吐槽,问题总是该解决的—在网上百度了很多vue单应用在ios系统中实现微信分享失败的原因以及解决方案原因原因单页面应用通过什么入口进去的 url保持不变 比如说入口是./index 后面不管页面怎么跳转 地址栏的地址都保持./index不变 这就导致微信分享的时候 地址栏的地址与当前页面的url不匹配 获取签名失败 所以分享就失败了~解决方案解决方案可以使用window.location.href去跳转,而不使用路由跳转,这样可以使地址栏的地址与当前页的地址一样,可以分享成功(适合分享的页面不多的情况下)把入口地址保存在本地,等需要获取签名的时候 取出来(有效~强推!!!)注意:sessionStorage.setItem(‘href',href); 只在刚进入单应用的时候保存!
mounted: function() {

this.$nextTick(function() { //vue里面全部加载好了再执行的函数 (类似于setTimeout)

this.myAddressSlots[0].defaultIndex = 0

});

var href = window.location.href;

if(!sessionStorage.getItem('href')){//将入口地址保存下来 ios分享会使用

sessionStorage.setItem('href',href);

}

},
mounted: function() {

this.$nextTick(function() { //vue里面全部加载好了再执行的函数 (类似于setTimeout)

this.myAddressSlots[0].defaultIndex = 0

});

var href = window.location.href;

if(!sessionStorage.getItem('href')){//将入口地址保存下来 ios分享会使用

sessionStorage.setItem('href',href);

}

},在使用存在本地的url去做分享的时候,建议安卓与iOS做判断,毕竟坑的只是iOS~
var url = 'lms-service/wechat-services/wechat-share-sign';

var curl = window.location.href;

if (!KZ.isAndroidOrIos() && KZ.isWeiXin()) {//isAndroidOrIos()安卓true IOS为false

curl = sessionStorage.getItem('href');

if(!curl){

curl = KZ_CONFIG.DOMAIN;

}

}
var url = 'lms-service/wechat-services/wechat-share-sign';

var curl = window.location.href;

if (!KZ.isAndroidOrIos() && KZ.isWeiXin()) {//isAndroidOrIos()安卓true IOS为false

curl = sessionStorage.getItem('href');

if(!curl){

curl = KZ_CONFIG.DOMAIN;

}

}好吧 就这样 能看到这篇博文的应该都是同路人~希望能够帮助到你们,还有就是 第一次写 思绪有点乱 多多包涵哈补充知识:vue 微信分享及ios二次微信分享invalid signature解决补充知识:补充知识:vue 微信分享及ios二次微信分享invalid signature解决我就废话不多说了,大家还是直接看代码吧~
npm install weixin-js-sdk
npm install weixin-js-sdk页面中引入
import wx from 'weixin-js-sdk'
import wx from 'weixin-js-sdk'
methods: {

init() {


var that = this;


var url = encodeURIComponent(window.location.href.split('#')[0]);


http.post(api.getSdk,url,function(data){




let appId = data.appId;




let timestamp = data.timestamp;




let signature = data.signature;




let nonceStr = data.nonceStr;




that.initwx(appId, timestamp, signature, nonceStr);


})


},


initwx(appId, timestamp, signature, nonceStr) {


var link = window.location.href;


var imgUrl = 'https格式的图片'


var shareData = {



"imgUrl": imgUrl,// 分享显示的缩略图地址 ,根据自己情况而定



"link": link,// 分享地址



"desc": '描述',// 分享描述



"title": '标题'// 分享标题


};


wx.config({



debug: false,//调试模式



appId: appId,// 公众号的唯一标识



timestamp: timestamp,//生成签名的时间戳



nonceStr: nonceStr,//生成签名的随机串



signature: signature,



jsApiList: ['onMenuShareTimeline', //



'onMenuShareAppMessage'] //


});


wx.checkJsApi({



jsApiList: ['onMenuShareTimeline', 'onMenuShareAppMessage']


});


wx.ready(function() {



wx.onMenuShareTimeline(shareData); //分享到朋友圈



wx.onMenuShareAppMessage(shareData); //分享给朋友


});

}
},
methods: {

init() {


var that = this;


var url = encodeURIComponent(window.location.href.split('#')[0]);


http.post(api.getSdk,url,function(data){




let appId = data.appId;




let timestamp = data.timestamp;




let signature = data.signature;




let nonceStr = data.nonceStr;




that.initwx(appId, timestamp, signature, nonceStr);


})


},


initwx(appId, timestamp, signature, nonceStr) {


var link = window.location.href;


var imgUrl = 'https格式的图片'


var shareData = {



"imgUrl": imgUrl,// 分享显示的缩略图地址 ,根据自己情况而定



"link": link,// 分享地址



"desc": '描述',// 分享描述



"title": '标题'// 分享标题


};


wx.config({



debug: false,//调试模式



appId: appId,// 公众号的唯一标识



timestamp: timestamp,//生成签名的时间戳



nonceStr: nonceStr,//生成签名的随机串



signature: signature,



jsApiList: ['onMenuShareTimeline', //



'onMenuShareAppMessage'] //


});


wx.checkJsApi({



jsApiList: ['onMenuShareTimeline', 'onMenuShareAppMessage']


});


wx.ready(function() {



wx.onMenuShareTimeline(shareData); //分享到朋友圈



wx.onMenuShareAppMessage(shareData); //分享给朋友


});

}
},
created(){

this.init();
},
created(){

this.init();
},备注:ios第二次分享 会出现invalid signature原因分享后出现微信会在链接会自动加以下字符串,再次签名的时候,因为&特殊字符传给后台,后台未处理,需要对链接encodeURIComponent处理,就不会出现invalid问题朋友圈 from=timeline&isappinstalled=0from=timeline&isappinstalled=0微信群 from=groupmessage&isappinstalled=0from=groupmessage&isappinstalled=0好友分享 from=singlemessage&isappinstalled=0from=singlemessage&isappinstalled=0以上这篇vue单应用在ios系统中实现微信分享功能操作就是小编分享给大家的全部内容了,希望能给大家一个参考。