微信小程序 支付功能前端的实现

微信小程序 支付功能(前端)的实现

只提供微信小程序代码

rush:js;">

var app = getApp();
Page({
data: {},onLoad: function (options) {
// 页面初始化 options为页面跳转所带来的参数
var that = this
//登陆获取code
wx.login({
success: function (res) {
console.log(res.code)
//获取openid
that.getopenId(res.code)
}
});
},getopenId: function (code) {
var that = this;
wx.request({
url: "https://api.weixin.qq.com/sns/jscode2session?appid=小程序appid&secret=小程序应用密钥&js_code=" + code + "&grant_type=authorization_code",data: {},method: 'GET',success: function (res) {
that.generateOrder(res.data.openid)
},fail: function () {
// fail
},complete: function () {
// complete
}
})
},/*生成商户订单 /
generateOrder: function (openid) {
var that = this
//统一支付
wx.request({
url: '后台路径',data: {
gfee: '商品价钱',gname: '商品名称',openId:openid
(商品价钱和商品名称根据自身需要是否传值,openid为必传)
},success: function (res) {
var pay = res.data
//发起支付
var timeStamp = pay[0].timeStamp;
var packages = pay[0].package;
var paySign = pay[0].paySign;
var nonceStr = pay[0].nonceStr;
var param = { "timeStamp": timeStamp,"package": packages,"paySign": paySign,"signType": "MD5","nonceStr": nonceStr };
that.pay(param)
},})
},/ 支付 /
pay: function (param) {
console.log("支付")
console.log(param)
wx.requestPayment({
timeStamp: param.timeStamp,nonceStr: param.nonceStr,package: param.package,signType: param.signType,paySign: param.paySign,success: function (res) {
// success
wx.navigateBack({
delta: 1,// 回退前 delta(认为1) 页面
success: function (res) {
wx.showToast({
title: '支付成功',icon: 'success',duration: 2000
})
},fail: function () {
// fail

      },complete: function () {
        // complete
      }
    })
  },fail: function (res) {
    // fail
  },complete: function () {
    // complete
  }
})

}
})

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持

相关文章

开发微信小程序的用户授权登录功能
小程序开发页面如何实现跳转?
浅谈小程序开发中蓝牙连接错误分析及解决方法
什么是小程序?它有哪些功能?
如何配置小程序开发项目结构?(教程)
怎么把自己的店加入小程序