vue单应用在ios系统中实现微信分享功能操作
表示是第一次使用vue做单应用显目,也是在逐渐的摸索中~更是各种踩坑,各种填坑,打算写博客么?是因为不想写笔记了,嗯嗯就是这么简单进入正题。
刚开始做微信分享的这个功能的时候,脑补了官方文档微信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
});
varhref=window.location.href;
if(!sessionStorage.getItem('href')){//将入口地址保存下来ios分享会使用
sessionStorage.setItem('href',href);
}
},
在使用存在本地的url去做分享的时候,建议安卓与iOS做判断,毕竟坑的只是iOS~
varurl='lms-service/wechat-services/wechat-share-sign';
varcurl=window.location.href;
if(!KZ.isAndroidOrIos()&&KZ.isWeiXin()){//isAndroidOrIos()安卓trueIOS为false
curl=sessionStorage.getItem('href');
if(!curl){
curl=KZ_CONFIG.DOMAIN;
}
}
好吧就这样能看到这篇博文的应该都是同路人~希望能够帮助到你们,还有就是第一次写思绪有点乱多多包涵哈
补充知识:vue微信分享及ios二次微信分享invalidsignature解决
我就废话不多说了,大家还是直接看代码吧~
npminstallweixin-js-sdk
页面中引入
importwxfrom'weixin-js-sdk'
methods:{
init(){
varthat=this;
varurl=encodeURIComponent(window.location.href.split('#')[0]);
http.post(api.getSdk,url,function(data){
letappId=data.appId;
lettimestamp=data.timestamp;
letsignature=data.signature;
letnonceStr=data.nonceStr;
that.initwx(appId,timestamp,signature,nonceStr);
})
},
initwx(appId,timestamp,signature,nonceStr){
varlink=window.location.href;
varimgUrl='https格式的图片'
varshareData={
"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();
},
备注:ios第二次分享会出现invalidsignature
原因分享后出现微信会在链接会自动加以下字符串,再次签名的时候,因为&特殊字符传给后台,后台未处理,需要对链接encodeURIComponent处理,就不会出现invalid问题
朋友圈from=timeline&isappinstalled=0
微信群from=groupmessage&isappinstalled=0
好友分享from=singlemessage&isappinstalled=0
以上这篇vue单应用在ios系统中实现微信分享功能操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。