小程序商品下單支付
小程序商品下單支付
[基礎用法]
功能:用于小程序的商品下單支付
用法:
第一步:在config.js文件中找到config設置
第二步:搜索一下shop_order_pay這個接口是否已經存在定義(有的小程序模板已經定義),如果沒有定義的話,在里面的底部新增以下代碼
shopOrderPayUrl: getApiUrl('shop_order_pay')
并復制紅色部分待用,如果已經存在,則直接復制使用即可
第三步:接口調用請求,如果定義名稱不同,使用第二步復制的內容替換紅框內選中的部分
提供參考的實例代碼:
/**
* 訂單提交
* 接收參數
* 無需接收參數,從頁面數據中取值
* 接口傳參
* addr_id:收貨地址ID
* prom_type:商品類型(虛擬、實物)
* pay_type:支付類型(微信、會員余額)
* remark:訂單備注
* coupon_id:優惠券ID
* querystr:訂單數據密鑰字符串
*/
onSubmitOrder() {
let _this = this;
// 防止重復提交訂單
if (_this.data.disabled) return false;
// 驗證是否需要添加收貨地址
let prom_type = _this.data.prom_type;
let addr_id = _this.data.address.addr_id || 0;
if (0 == addr_id && 0 == prom_type) {
App.showError('請添加收貨地址', function() {
_this.onSelectAddress();
});
return false;
}
// 接口傳參
let postData = {
addr_id: addr_id,
prom_type: prom_type,
pay_type: _this.data.curPayType,
remark: _this.data.remark || '',
coupon_id: _this.data.selectCouponId,
querystr: _this.data.options.querystr,
};
// 秒殺商品參數
if (_this.data.product_data[0].active_time_id) {
postData.order_source = '20';
postData.order_source_id = _this.data.product_data[0].active_time_id;
}
App._requestPost(_this, App.globalData.config.shopOrderPayUrl, postData,
function (res) {
let order_id = res.data.OrderData.order_id;
let order_code = res.data.OrderData.order_code;
_this.setData({ order_id, order_code });
if (_this.data.curPayType == 1) {
if (res.data.WeChatPay.return_code == 'FAIL') {
App.showError(res.data.WeChatPay.return_msg);
return false;
}
App.wxPayment({
order_id: order_id,
payment: res.data.WeChatPay,
success: res1 => {
_this.setData({
is_cart_pay: _this.data.options.querystr ? false : true,
is_buy_pay: _this.data.options.querystr ? true : false
});
_this._orderPayDealWith();
},
fail: res1 => {
if (!res.msg.error) App.showError(res.msg.error);
},
});
} else if (_this.data.curPayType == 2) {
App.showSuccess(res.msg, () => {
_this.redirectToOrderIndex();
});
}
},
function (res) {
App.showError(res.msg);
}
);
},
文檔最后更新時間:2023-03-01 11:17:53
未解決你的問題?請到「問答社區」反饋你遇到的問題