微信h5支付

export function chooseWXPay(params: wx.ChooseWXPayConfig) {
    return new Promise<{
        status: 'success' | 'error' | 'cancel';
        result?: string;
        message?: string;
        [key: string]: any;
    }>((resolve, reject) => {
        if (!store.state.jssdk || !store.state.jssdk.jssdkReady) {
            Toast(`微信支付加载失败`);
            return;
        }

        wx.chooseWXPay({
            timestamp: params.timestamp,
            nonceStr: params.nonceStr,
            package: params.package,
            signType: params.signType,
            paySign: params.paySign,
            // 支付成功后的回调函数
            success: (res: WeixinJSSDKCallbackParams) => {
                if (res.errMsg === 'chooseWXPay:ok') {
                    resolve({ // 支付成功
                        status: 'success',
                    });
                } else if (res.errMsg === 'chooseWXPay:cancel') {
                    resolve({ // 支付成功
                        status: 'cancel',
                    });
                } else {
                    resolve({
                        status: 'error',
                        result: res.errMsg,
                        message: res.errMsg,
                    });
                }
            },
            cancel: () => {
                resolve({ // 支付成功
                    status: 'cancel',
                });
            },
            fail: (res: WeixinJSSDKCallbackParams) => {
                resolve({
                    status: 'error',
                    result: res.errMsg,
                    message: res.errMsg,
                });
            },
        });
    });
}
posted @   walxl  阅读(52)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
点击右上角即可分享
微信分享提示