vue项目在PC端的支付调用(支付宝和微信支付使用qrcodejs2渲染二维码)

使用vue写pc端项目时,商城类网站通常需要接支付系统,下面是我在最近一个商城项目中关于支付系统的记录

支付宝支付

支付宝支付对于前端来说比较简单,只需要后端同志把要跳转的页面接口配置好,前端拼接上跳转参数直接跳转就好,代码示例:

//支付宝付款
        //拼接url  其中this.https.urls是后端给接口地址,,其他为参数
        let myurl =this.https.urls +"/index/memory/familytree_pay?user_id" + localStorage.getItem("ym_userId") + "&order=" +order;
        //直接跳转
        window.location.href = myurl;
微信支付

微信支付较为复杂点,因为微信会返回一个特殊链接,一般需要前端转换成一个二维码进行扫码支付,现在先引入一个转换二维码的插件qrcodejs2
1.引入qrcodejs2

npm install  qrcodejs2 --save

2.在需要的页面引入

import QRCode from "qrcodejs2"; // 引入qrcode

3.微信支付中,在弹出二维码等待微信扫码时,pc端无法得到扫码支付结果,所以需要设置定时器不间断的请求后端提供的一个接口,用来判断是否支付完成

微信弹框的html:

<!-- 微信支付弹框 -->
    <el-dialog :visible.sync="buy_code" width="80rem" @close="buy_close">
      <div class="buy_box dis_f_c_c">
        <div id="qrcode" ref="qrcode" class="img1 dis_f_c_c"></div>
        <img src="static/image/store/pay2.png" class="img2" alt="" />
      </div>
    </el-dialog>
  </div>
  //重点是要有div的ref=qrcode,便于接下来渲染二维码

js:

              this.buy_code = true;//显示二维码弹窗
              //循环请求查看是否支付成功
              this.timer1 = setInterval(() => {
                this.wx_time(order);
              }, 1000);
              //使用nextTick确保在弹框显示前二维码数据渲染,不加的话可能报错获取不到qrcode元素
              this.$nextTick(() => {
                this.qrcode = new QRCode("qrcode", {
                  width: 150,//二维码宽度
                  height: 150,//二维码高度
                  text: res.data.data,//调用微信支付接口返回的微信特殊链接:例如"weixin://wxpay/bizpayurl?pr=uDKsQ4E00"
                  colorDark: "#000",//颜色配置
                  colorLight: "#fff",
                });
              });
              

关闭弹框js:

//监听支付成功后
     //成功后关闭定时器
      clearInterval(this.timer1);
      this.$refs.qrcode.innerHTML = "";//清空渲染的二维码
      this.buy_code = false;//关闭弹窗

支付结束!,下面是图片实列
在这里插入图片描述

要在 Vue PC端生成微信二维码进行支付,你可以使用第三方库,如 `qrcode` 来生成二维码,并且使用微信支付的 API 来实现支付功能。 首先,你需要安装 `qrcode` 库。你可以使用 npm 命令进行安装: ``` npm install qrcode --save ``` 接下来,在你的 Vue 组件中,你可以使用以下代码生成二维码: ```javascript import QRCode from 'qrcode' export default { data() { return { qrcodeUrl: '' // 用于存储生成的二维码图片地址 } }, methods: { generateQRCode() { const el = this.$refs.qrcode const url = '这里是二维码的内容,可以是一个链接或其他字符串' QRCode.toDataURL(url, { errorCorrectionLevel: 'H', margin: 1 }) .then(dataUrl => { this.qrcodeUrl = dataUrl }) .catch(err => { console.error(err) }) } } } ``` 这里使用 `QRCode.toDataURL()` 方法生成二维码,并将生成的图片地址存储在 `qrcodeUrl` 变量中。你可以将 `qrcodeUrl` 绑定到一个 `img` 标签上来显示二维码图片。 接下来,你需要实现微信支付功能。你可以使用微信支付的 API 来完成支付流程,具体步骤如下: 1. 获取支付参数:你需要向服务器发送请求,获取支付所需的参数,包括订单号、金额、签名等。 2. 调起微信支付调用 `wx.chooseWXPay()` 方法,将支付参数传递给微信支付接口进行支付。 ```javascript // 获取支付参数 axios.get('/api/getPayParams') .then(res => { const params = res.data // 调起微信支付 wx.chooseWXPay({ timestamp: params.timestamp, // 时间戳 nonceStr: params.nonceStr, // 随机字符串 package: params.package, // 包含预支付订单 ID 的字符串 signType: params.signType, // 签名类型 paySign: params.paySign, // 签名 success: res => { // 支付成功 console.log('支付成功', res) }, fail: err => { // 支付失败 console.error('支付失败', err) } }) }) .catch(err => { console.error(err) }) ``` 注意,以上代码中的 `wx.chooseWXPay()` 方法需要在微信公众号中使用,如果需要在 PC 端使用,可以使用模拟器或者其他工具进行测试。 希望这能帮助到你。如果你有其他问题,请随时提出。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值