封装微信公众h5调用微信支付
1、安装 weixin-js-sdk
npm install weixin-js-sdk
2、引用 weixin-js-sdk
1 | const wx = require( 'weixin-js-sdk' ); |
3、结合后台传过来的参数
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 | wx.config({ debug: false , appId: data.appId, timestamp: data.timeStamp, nonceStr: data.nonceStr, signature: data.paySign, jsApiList: [ 'chooseWXPay' ] }); wx.ready(() => { wx.chooseWXPay({ timestamp: data.timeStamp, //这个字段是为字符串后端返回时需检查 nonceStr: data.nonceStr, package : data. package , signType: data.signType, paySign: data.paySign, success(res) { r({ code: 0, msg: "成功" }); }, cancel() { r({ code: 1, msg: "取消" }); }, fail(err) { r({ code: 2, msg: err.errMsg.split( ':' )[1] || '支付失败!' }); }, // 无论失败成功都会执行 complete(e) { // e.errMsg三种状态 1.chooseWXPay:ok 支付成功 2: chooseWXPay:cancel 支付取消 3:chooseWXPay:fail 支付失败 if (e.errMsg === 'chooseWXPay:ok' ) { if (jumpUrl) { window.location.href = jumpUrl } else { window.location.reload() } } } }); }); wx.error( function (err) { r({ code: 2, msg: '支付失败!' }); }); }) |
完整代码(新建js文件放置):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | const wx = require( 'weixin-js-sdk' ); export default { wexinPay(data, jumpUrl) { return new Promise(r => { wx.config({ debug: false , appId: data.appId, timestamp: data.timeStamp, nonceStr: data.nonceStr, signature: data.paySign, jsApiList: [ 'chooseWXPay' ] }); wx.ready(() => { wx.chooseWXPay({ timestamp: data.timeStamp, //这个字段是为字符串后端返回时需检查 nonceStr: data.nonceStr, package : data.packageValue, signType: data.signType, paySign: data.paySign, success(res) { r({ code: 0, msg: "成功" }); }, cancel() { r({ code: 1, msg: "取消" }); }, fail(err) { r({ code: 2, msg: err.errMsg.split( ':' )[1] || '支付失败!' }); }, // 无论失败成功都会执行 complete(e) { // e.errMsg三种状态 1.chooseWXPay:ok 支付成功 2: chooseWXPay:cancel 支付取消 3:chooseWXPay:fail 支付失败 if (e.errMsg === 'chooseWXPay:ok' ) { if (jumpUrl) { window.location.href = jumpUrl } else { window.location.reload() } } } }); }); wx.error( function (err) { r({ code: 2, msg: '支付失败!' }); }); }) } } |
调用:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 | import $wxPay from '@/utils/wxPay.js' this .$u.api.wechatPayApi({ orderList: this .curOrderList, openid: this .vuex_wxinfo.openId }).then(res => { if (res.code === 200) { $wxPay.wexinPay(res.data.wx).then(res1 => { switch (Number(res1.code)) { case 0: // 成功 //#ifdef H5 window.location.reload(); //#endif break ; case 1: // 取消 this .$refs.uToast.show({ title: '已取消支付' , type: 'info' }); break ; case 2: // 支付失败 this .$refs.uToast.show({ title: '支付失败,请检查!' , type: 'error' }); break ; } }) } }) |
自己根据后台接口适当调整!
希望大佬看到有不对的地方,提出博主予以改正!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律