表示是第一次使用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 }); 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; } }
好吧 就这样 能看到这篇博文的应该都是同路人~希望能够帮助到你们,还有就是 第一次写 思绪有点乱 多多包涵哈
补充知识:vue 微信分享及ios二次微信分享invalid signature解决
我就废话不多说了,大家还是直接看代码吧~
npm install 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); //分享给朋友 }); } },
created(){ this.init(); },
备注:ios第二次分享 会出现invalid signature
原因分享后出现微信会在链接会自动加以下字符串,再次签名的时候,因为&特殊字符传给后台,后台未处理,需要对链接encodeURIComponent处理,就不会出现invalid问题
朋友圈 from=timeline&isappinstalled=0
微信群 from=groupmessage&isappinstalled=0
好友分享 from=singlemessage&isappinstalled=0
以上这篇vue单应用在ios系统中实现微信分享功能操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍iOS 微信分享功能简单实现,包括了iOS 微信分享功能简单实现的使用技巧和注意事项,需要的朋友参考一下 PS:此文以简单实现功能为主,不足之前还望指点,大神勿喷. 在此之前如何申请微信认证的Key就不说了,公司一般会有人搞(自己申请一个也非常的简单) 1.首先下载微信SDK:微信SDK下载地址(更多关于微信SDK信息文档请访问官方网站:微信开放平台) 2.导入微信SDK 将下载下来
本文向大家介绍iOS实现微信分享多张图片功能,包括了iOS实现微信分享多张图片功能的使用技巧和注意事项,需要的朋友参考一下 前言 微信分享到朋友圈,可分享的类型有:文字类型、图片类型、音乐类型、视频类型和网页类型,但是我们在做图片分享的时候发现微信给的API只能分享一张图片,达不到一些APP的需求,而产品汪或者Boss想要分享多张图片,比如前段时间我做的一个APP,是电商类APP,想把商品的图片都
本文向大家介绍详解Android系统中跨应用数据分享功能的实现,包括了详解Android系统中跨应用数据分享功能的实现的使用技巧和注意事项,需要的朋友参考一下 一个Andoird应用程序的重要的地方是他们有相互沟通和整合的能力,一个应用程序可以和另一个应用程序交互,接下来我们来看看Android应用之间的内容分享 当你构建Intent的时候,必须要指定Intent的Action触发,定义Inten
本文向大家介绍微信JS-SDK分享功能的.Net实现代码,包括了微信JS-SDK分享功能的.Net实现代码的使用技巧和注意事项,需要的朋友参考一下 JS-SDK接口是什么? 为了方便开发者实现微信内的网页(基于微信浏览器访问的网页)功能,比如拍照、选图、语音、位置等手机系统的能力,并方便开发者直接使用微信分享、扫一扫等微信特有的能力,微信推出了JS-SDK的整体开发包,供开发者方便使用。 分享功能
本文向大家介绍java调用微信接口实现网页分享小功能,包括了java调用微信接口实现网页分享小功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了java调用微信接口实现网页分享小功能的具体代码,供大家参考,具体内容如下 // 获取access_token *注意* 经过实际开发测试,微信分享不支持跨域请求,因此获取access_token的请求必须从服务器发起,否则无法获取到ac
本文向大家介绍Swift实现iOS应用中短信验证码倒计时功能的实例分享,包括了Swift实现iOS应用中短信验证码倒计时功能的实例分享的使用技巧和注意事项,需要的朋友参考一下 在开始之前,我们先来了解一个概念 属性观测器(Property Observers): 属性观察器监控和响应属性值的变化,每次属性被设置值的时候都会调用属性观察器,甚至新的值和现在的值相同的时候也不例外。 可以为属性添加如下