vue单应用在ios系统中实现微信分享功能操作


Posted in Javascript onSeptember 07, 2020

表示是第一次使用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系统中实现微信分享功能操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
整理一些JavaScript的IE和火狐的兼容性注意事项
Mar 17 Javascript
js iframe跨域访问(同主域/非同主域)分别深入介绍
Jan 24 Javascript
JS localStorage实现本地缓存的方法
Jun 22 Javascript
js中符号转意问题示例探讨
Aug 19 Javascript
验证码在IE中不刷新而谷歌等浏览器正常的解决方案
Mar 18 Javascript
jQuery表单验证插件解析(推荐)
Jul 21 Javascript
AngularJS基础 ng-submit 指令简单示例
Aug 03 Javascript
浅谈js使用in和hasOwnProperty获取对象属性的区别
Apr 27 Javascript
Vue 2.0的数据依赖实现原理代码简析
Jul 10 Javascript
Angular通过angular-cli来搭建web前端项目的方法
Jul 27 Javascript
使用classList来实现两个按钮样式的切换方法
Jan 24 Javascript
JavaScript 中的执行上下文和执行栈实例讲解
Feb 25 Javascript
vue 微信分享回调iOS和安卓回调出现错误的解决
Sep 07 #Javascript
一篇文章带你从零快速上手Rollup
Sep 07 #Javascript
基于vue hash模式微信分享#号的解决
Sep 07 #Javascript
在项目vue中使用echarts的操作步骤
Sep 07 #Javascript
解决vue加scoped后就无法修改vant的UI组件的样式问题
Sep 07 #Javascript
Vue.js原理分析之nextTick实现详解
Sep 07 #Javascript
小程序实现可拖动的悬浮按钮
Sep 07 #Javascript
You might like
基于php伪静态的实现详细介绍
2013/04/28 PHP
ThinkPHP数据操作方法总结
2015/09/28 PHP
php利用gd库为图片添加水印
2016/11/09 PHP
php实现购物车功能(以大苹果购物网为例)
2017/03/09 PHP
PHP使用preg_split和explode分割textarea存放内容的方法分析
2017/07/03 PHP
javascript 三种编解码方式
2010/02/01 Javascript
javascript中xml操作实现代码
2011/11/21 Javascript
JavaScript Ajax Json实现上下级下拉框联动效果实例代码
2013/11/23 Javascript
JavaScript检测鼠标移动方向的方法
2015/05/22 Javascript
js实现带圆角的两级导航菜单效果代码
2015/08/24 Javascript
学习JavaScript图片预加载模块
2016/11/07 Javascript
微信小程序通过api接口将json数据展现到小程序示例
2017/01/20 Javascript
JS实现获取图片大小和预览的方法完整实例【兼容IE和其它浏览器】
2017/04/24 Javascript
JavaScript定义函数的三种实现方法
2017/09/23 Javascript
JavaScript使用小插件实现倒计时的方法讲解
2019/03/11 Javascript
详解小程序input框失焦事件在提交事件前的处理
2019/05/05 Javascript
用jQuery实现抽奖程序
2020/04/12 jQuery
js实现简易点击切换显示或隐藏
2020/11/29 Javascript
Python3实现并发检验代理池地址的方法
2016/09/18 Python
Python简单格式化时间的方法【strftime函数】
2016/09/18 Python
Python函数参数操作详解
2018/08/03 Python
浅谈pandas筛选出表中满足另一个表所有条件的数据方法
2019/02/08 Python
python删除列表元素的三种方法(remove,pop,del)
2019/07/22 Python
Django中F函数的使用示例代码详解
2020/07/06 Python
Python常用GUI框架原理解析汇总
2020/12/07 Python
里程积分管理买卖交换平台:Points.com
2017/01/13 全球购物
优衣库美国官网:UNIQLO美国
2018/04/14 全球购物
教师自我鉴定
2013/12/13 职场文书
课改先进个人汇报材料
2014/01/26 职场文书
材料专业毕业生求职信
2014/02/26 职场文书
我们的节日国庆活动方案
2014/08/19 职场文书
党员自评材料范文
2014/12/17 职场文书
小学运动会入场口号
2015/12/24 职场文书
2016计算机专业毕业生自荐信
2016/01/28 职场文书
SQL Server远程连接的设置步骤(图文)
2022/03/23 SQL Server
Redis官方可视化工具RedisInsight安装使用教程
2022/04/19 Redis