详解vue项目接入微信JSSDK的坑


Posted in Javascript onDecember 14, 2018

用于记录接入微信JS-SDK的坑,以后方便查询 第一次接入公众号微信支付、分享、定位等等的坑的时候,心里是迷茫而又恐惧。因为,听说坑特别多,后来发现自己的亲身体验到了这一点。

支付的坑

1、当前URL未注册

详解vue项目接入微信JSSDK的坑

问题: 微信公众号H5调起支付时,点击支付按钮出现“当前页面的URL未注册”的提示。

解决办法:由于2017年8月1日微信官方把关于支付的信息转移到了商户平台:公众平台微信支付公众号支付授权目录、扫码支付回调URL配置入口已于8月1日迁移至商户平台(pay.weixin.qq.com )

所以进入以下位置:

登录微信商户平台-产品中心-开发配置,配置支付授权路径。如果掉起支付的页面在 域名/pay.html中,那么就在此添加授权路径, 如我的掉起支付的页面在www.weixinPay.com/pay.html 中,那么授权目录就配置为htt://www.weixinPay.com/

tip: 注意:后面的 / 一定要加上,表示该路径下的页面都可以调起微信的支付接口。

详解vue项目接入微信JSSDK的坑

2、如果按照以上还是弹出当前URL未注册 因为微信支付对spa项目的hash路由兼容还是不很好。需要加上一个 "?" 如图:

详解vue项目接入微信JSSDK的坑

代码如下:

watch: {
 $route() {
  this.directRightUrl()
 }
},
methods: {
 directRightUrl() {
 let { href, protocol, host, pathname, search, hash } = window.location
 search = search || '?'
 let newHref = `${protocol}//${host}${pathname}${search}${hash}`
 if (newHref !== href) {
  window.location.replace(newHref)
 }
 }

我这里是根据App.vue文件,进行路由监控。然后给每个页面都加上问号,虽然会些许性能消耗。但是方便省事,具体可以根据自己的页面适当修改。

微信JS-SDK说明文档

分享的坑

根据JS-SDK的文档,很多人都是在初始化的wx配置的时候,传入的当前的URL地址不正确。 然后就导致如下结果:

详解vue项目接入微信JSSDK的坑

解决办法: 请在保证后台能正确返回初始化需要的配置参数的情况下

详解vue项目接入微信JSSDK的坑

修改前:
// let currentUrl = window.location.href
修改后
let currentUrl = window.location.href.split('#')[0]

神奇成功了开心

详解vue项目接入微信JSSDK的坑

需要注意的几点:

jsApList: [] 需要加入对应参数。比如,分享加入'onMenuShareTimeline', 'onMenuShareAppMessage'。 具体的对应接口的参数可以参考文档

所有接口的调用,请保证在wx.ready()执行后,才调用。文档里面是这么建议的。

详解vue项目接入微信JSSDK的坑

定位的坑

刚开始定位的,内心是有点小激动的。因为觉得这个功能很高大尚,当然了这只是我个人的想法。好了~,不扯了。

同样的,给微信初始化的 jsApList 加入对应的参数。 然后在wx.ready()函数执行,但是,发现无论如何第一次进入页面都无法成功弹出授权弹框。

详解vue项目接入微信JSSDK的坑

后来发现,在页面完成之后。延迟一秒再进行获取定位,即可 百分百成功!坑爹有木有。 代码如下

详解vue项目接入微信JSSDK的坑

详解vue项目接入微信JSSDK的坑

目前遇到这个三个坑,后期遇到再写上吧。痛苦的经历需要不要再有了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
再谈javascript面向对象编程
Mar 18 Javascript
Json和Jsonp理论实例代码详解
Nov 15 Javascript
一分钟理解js闭包
May 04 Javascript
javascript 内置对象及常见API详细介绍
Nov 01 Javascript
jquery.zclip轻量级复制失效问题
Jan 08 Javascript
原生JS实现幻灯片
Feb 22 Javascript
Javascript仿京东放大镜的效果
Mar 01 Javascript
微信小程序开发问题之wx.previewImage
Dec 25 Javascript
JavaScript中.min.js和.js文件的区别讲解
Feb 13 Javascript
ES6中let、const的区别及变量的解构赋值操作方法实例分析
Oct 15 Javascript
微信小程序自定义底部弹出框动画
Nov 18 Javascript
详解JSON.parse和JSON.stringify用法
Feb 18 Javascript
微信小程序实现动态显示和隐藏某个控件功能示例
Dec 14 #Javascript
javascript中的event loop事件循环详解
Dec 14 #Javascript
如何在Vue中使用CleaveJS格式化你的输入内容
Dec 14 #Javascript
webpack配置proxyTable时pathRewrite无效的解决方法
Dec 13 #Javascript
node.js学习笔记之koa框架和简单爬虫练习
Dec 13 #Javascript
浅谈vuex actions和mutation的异曲同工
Dec 13 #Javascript
webpack3里使用uglifyjs压缩js时打包报错的解决
Dec 13 #Javascript
You might like
Yii模型操作之criteria查找数据库的方法
2016/07/15 PHP
PHP如何使用cURL实现Get和Post请求
2020/07/11 PHP
Javascript匿名函数的一种应用 代码封装
2010/06/27 Javascript
基于Jquery的开发个代阴影的对话框效果代码
2011/07/28 Javascript
jquery的总体架构分析及实现示例详解
2014/11/08 Javascript
javascript引用赋值(地址传值)用法实例
2015/01/13 Javascript
JS实现的4种数字千位符格式化方法分享
2015/03/02 Javascript
JavaScript将一个数组插入到另一个数组的方法
2015/03/19 Javascript
js的各种排序算法实现(总结)
2016/07/23 Javascript
AngularJS ng-bind-html 指令详解及实例代码
2016/07/30 Javascript
vue router路由嵌套不显示问题的解决方法
2017/06/17 Javascript
微信小程序的生命周期的详解
2017/10/19 Javascript
vue2.0 根据状态值进行样式的改变展示方法
2018/03/13 Javascript
使用validate.js实现表单数据提交前的验证方法
2018/09/04 Javascript
微信小程序实现左滑修改、删除功能
2020/10/19 Javascript
JavaScript HTML DOM元素 节点操作汇总
2019/07/29 Javascript
解决vue动态下拉菜单 有数据未反应的问题
2020/08/06 Javascript
浅谈vue项目,访问路径#号的问题
2020/08/14 Javascript
进一步探究Python中的正则表达式
2015/04/28 Python
Python中应该使用%还是format来格式化字符串
2018/09/25 Python
python pandas 时间日期的处理实现
2019/07/30 Python
Python环境下安装PyGame和PyOpenGL的方法
2020/03/25 Python
Sunglasses Shop瑞典:欧洲领先的太阳镜网上商店
2018/04/22 全球购物
Shell编程面试题
2012/05/30 面试题
中学运动会广播稿
2014/01/19 职场文书
岗位职责的构建方法
2014/02/01 职场文书
企业文明单位申报材料
2014/05/16 职场文书
化学专业大学生职业生涯规划范文
2014/09/13 职场文书
党员剖析材料范文
2014/09/30 职场文书
小班下学期幼儿评语
2014/12/30 职场文书
大学四年个人总结
2015/03/03 职场文书
通讯稿格式及范文
2015/07/22 职场文书
工伤事故赔偿协议书
2015/08/06 职场文书
使用HTML+Css+transform实现3D导航栏的示例代码
2021/03/31 HTML / CSS
详解Redis瘦身指南
2021/05/26 Redis
Python测试框架pytest高阶用法全面详解
2022/06/01 Python