生成微信支付二维码(前端)

1、在api下创建接口方法(order.js)

java 复制代码
//根据订单号生成支付二维码
   createNative(orderNo) {
    return request({
      url: `/orderservice/paylog/createNative/${orderNo}`,
      method: 'get'
    })
  }

2、点击"去支付"(/order/_oid.vue),跳转支付页面,显示二维码

java 复制代码
asyncData({ params, error }) {
    //调用接口
    return order.getOrderInfo(params.oid).then(response => {
      //得到返回的两个结果
      return {
        order:response.data.data.orderInfo,
        orderNo:params.oid
      };
    });
  },
  methods: {
    toPay(){
        //跳转到支付页面
        this.$router.push({path:'/pay/'+this.orderNo})
    }  
  }

3、支付页面、显示二维码

(1)有vue组件展现二维码

(2)创建动态路由pages/pay/_pid.vue页面,添加页面元素

java 复制代码
<template>
  <div class="cart py-container">
    <!--主内容-->
    <div class="checkout py-container  pay">
      <div class="checkout-tit">
        <h4 class="fl tit-txt"><span class="success-icon"></span><span class="success-info">订单提交成功,请您及时付款!订单号:{{payObj.out_trade_no}}</span>
        </h4>
        <span class="fr"><em class="sui-lead">应付金额:</em><em class="orange money">¥{{payObj.total_fee}}</em></span>
        <div class="clearfix"></div>
      </div>
      <div class="checkout-steps">
        <div class="fl weixin">微信支付</div>
        <div class="fl sao">
          <p class="red">请使用微信扫一扫。</p>
          <div class="fl code">
            <!-- <img id="qrious" src="~/assets/img/erweima.png" alt=""> -->
            <!-- <qriously value="weixin://wxpay/bizpayurl?pr=R7tnDpZ" :size="338"/> -->
            <qriously :value="payObj.code_url" :size="338"/>
            <div class="saosao">
              <p>请使用微信扫一扫</p>
              <p>扫描二维码支付</p>
            </div>

          </div>

        </div>
        <div class="clearfix"></div>
        <!-- <p><a href="pay.html" target="_blank">> 其他支付方式</a></p> -->
        
      </div>
    </div>
  </div>
</template>

(3)pages/pay/_pid.vue页面js方法实现

java 复制代码
import order from "@/api/order";
export default {
   //异步请求操作
  asyncData({ params, error }) {
    //调用接口
    return order.createNative(params.pid).then(response => {
      //得到返回的两个结果
      return {
        payObj:response.data.data
      };
    });
  }
}

(4)测试

相关推荐
糕冷小美n2 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥2 小时前
Technical Report 2024
java·服务器·前端
沐墨染2 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion2 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks2 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
苍何2 小时前
即梦Seedance2.0海外火爆出圈,AI 视频的 DeepSeek 时刻来了!(附实测教程)
后端
苍何2 小时前
阿里卷麻了,千问 Qwen-Image-2.0 发布,超强文字渲染、信息图、PPT 轻松做(附实测提示词)
后端
苍何2 小时前
被马斯克疯狂点赞的国产 AI,很可能是 AI 时代的抖音!
后端
苍何3 小时前
国产Windows 版 Claude Cowork 来了,内置海量 Skills,绝了。
后端
问道飞鱼3 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建