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

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)测试

相关推荐
打瞌睡的朱尤3 小时前
Vue day10 完整购物网页(登录页,首页,搜索)
前端·javascript·vue.js
RFG20123 小时前
20、详解Dubbo框架:消费方如何动态获取服务提供方地址?【微服务架构入门】
java·人工智能·后端·微服务·云原生·架构·dubbo
扶苏10024 小时前
深入理解 Vue 3 的 watchEffect
前端·javascript·vue.js
TimberWill4 小时前
SpringBoot整合Srping Security实现权限控制
java·spring boot·后端
未来龙皇小蓝6 小时前
RBAC前端架构-05:引入Element-UI及相关逻辑
前端·ui
yanlele6 小时前
AI Coding 时代下, 关于你会写代码这件事儿, 还重要吗?
前端·javascript·ai编程
打瞌睡的朱尤7 小时前
Vue day9 购物车,项目,vant组件库,vw,路由
前端·javascript·vue.js
米羊1217 小时前
Struts 2 漏洞(上)
java·后端·struts
梵得儿SHI7 小时前
Spring Cloud 实战攻坚:企业级用户服务开发(注册登录 + JWT 认证 + 权限控制)
后端·spring·spring cloud·用户注册与登录·jwt无状态认证体系·rbac权限控制·微服务用户中心
Tadas-Gao8 小时前
基于规范驱动开发的下一代软件工程范式:从理论到实践
驱动开发·架构·系统架构·大模型·llm·软件工程