paypal支付,官网
实例
引入cdn
在加载该组件时就读取脚本
data() {
return {
clientId:'AbJmdo6IqMHBMfgJVP-qWfFacVBBDOE45hOJGp8_XpZ1uq4ytOzOPDX4jw2p0pUTPmNptRA40BEqgdXf', // paypal客户端id
};
},
mounted() {
this.initScript()
},
methods: {
// 加载paypal脚本
initScript(){
const setLoaded = ()=>{
// console.log('初始化--加载script')
}
// 在页面中创建script标签
const script = document.createElement("script");
// 给script标签加src 链接到paypal
// script.src = "https://www.paypal.com/sdk/js?client-id=YOU_CLIENT_id";
// 测试连接 沙盒
// script.src = "https://www.paypal.com/sdk/js?client-id=test&components=buttons,marks";
script.src = `https://www.paypal.com/sdk/js?client-id=${this.clientId}`;
script.addEventListener("load", setLoaded);
document.body.appendChild(script);
}
}
渲染生成元素组件
通过监听变化,再初始化渲染组件
<div ref="paypalBtnBox"></div>
watch: {
visible: {
handler(val, oldVal) {
this.popupStatus = val;
if (val) {
this.paypalResultStatus = false;
if (window.paypal) {
// console.log("已加载---");
let _this = this;
this.$nextTick(() => {
_this.initPaypal(_this);
});
} else {
// console.log("未加载---");
}
}
},
deep: true,
immediate: true,
},
},
methods: {
// 初始化paypal组件
async initPaypal(_this) {
_this.$refs.paypalBtnBox.innerHTML = ''; // 清空元素内容
window.paypal
.Buttons({
style: {
layout: 'vertical',//按钮样式
color: 'gold',//颜色
shape: 'pill',//
label: 'checkout',//按钮文本
tagline: false //
},
// locale: 'zh_CN',//按钮的语言
async createOrder() {
// 创建
try {
//创建订单xgemBuyPaypal
const response = await xgemBuyPaypal(_this.paypalOrder)
.then((resp) => {
_this.paypalRespond = resp?.data;
// console.log("--paypal---resp", _this.paypalRespond);
return _this.paypalRespond;
})
.catch((err) => {
_this.$notice.error(err);
return Promise.reject(err);
});
const orderData = await response;
if (orderData?.payPalOrderId) {
return orderData?.payPalOrderId;
} else {
const errorDetail = orderData?.details?.[0];
const errorMessage = errorDetail
? `${errorDetail.issue} ${errorDetail.description} (${orderData.debug_id})`
: JSON.stringify(orderData);
throw new Error(errorMessage);
}
} catch (err) {
_this.$notice.error(err);
}
},
async onApprove(data, actions) {
// 用户支付回调
await actions.order.capture()
.then((details) => {
// 支付成功
let orderNumber,orderAmount;
// 订单id
orderNumber = details.id;
//订单支付的金额
orderAmount = details.purchase_units[0].amount.value;
_this.goResultPage(true)
// console.log('支付成功---1-',details, orderNumber,orderAmount);
}).catch((err)=>{
//支付失败
_this.goResultPage(false)
// console.log('支付失败----',err)
});
_this.paypalApprove(_this,data,actions)
},
onCancel: function(data) {
// 在付款取消时执行的操作
// console.log('在付款取消时执行的操作---',data)
},
onClick: function(data) {
// 在点击支付按钮时执行的操作
// console.log('在点击支付按钮时执行的操作---',data)
},
})
.render(_this.$refs.paypalBtnBox);
},
}
完整代码
引用
<PaypalPop
:visible="PaypalPopupStatus"
:paypal-order="paypalOrderParams"
@closeEvent="showPaypalPopEvent"
@success="paymentSuccess">
</PaypalPop>
PaypalPop.vue
查看代码
<template>
<div>
<Popup
class="popup-paypal"
:closeable="paypalResultStatus?false:true"
v-model="popupStatus"
get-container="body"
:close-on-click-overlay="false"
:position="bottomOrCenter"
@click.stop
@close="handleClose(1)"
>
<div class="paypal-button-container-box" v-if="!paypalResultStatus">
<div ref="paypalBtnBox"></div>
</div>
<PaypalResult v-else :atype="paypalResultType" @closeEvent="handleClose(2)"></PaypalResult>
</Popup>
</div>
</template>
<script>
import { reportOrderNFTPaypal } from "@/api/http.account";
import { xgemBuyPaypal } from "@/api/nft/http.nft";
import { Popup } from "vant";
import PaypalResult from "@/components/PaypalResult.vue";
export default {
name: "Paypal",
components: {
Popup,
PaypalResult,
},
props: {
paypalOrder: Object,
visible: Boolean,
},
// paypalOrder
data() {
return {
popupStatus: this.visible,
paypalRespond: null, // paypal创建订单后的回调
reportOrder: null, // 上报的订单
bottomOrCenter: "bottom",
paypalResultStatus: false, // 是否显示结果
paypalResultType: false, // 结果状态
clientId:'AbJmdo6IqMHBMfgJVP-qWfFacVBBDOE45hOJGp8_XpZ1uq4ytOzOPDX4jw2p0pUTPmNptRA40BEqgdXf', // paypal客户端id
};
},
watch: {
visible: {
handler(val, oldVal) {
this.popupStatus = val;
if (val) {
this.paypalResultStatus = false;
if (window.paypal) {
// console.log("已加载---");
let _this = this;
this.$nextTick(() => {
_this.initPaypal(_this);
});
} else {
this.$notice.error(this.$t('fomo.FOMO_EGAIN'));
// console.log("未加载---");
}
}
},
deep: true,
immediate: true,
},
},
created() {
},
mounted() {
this.initScript()
},
methods: {
//关闭当前弹窗,val:1为右上角的关闭 2为结果页的关闭
handleClose(val) {
this.popupStatus = false;
this.$emit("closeEvent", val); //发送给子类 自定义方法
return;
},
// 通过是判断paypal支付结果
// this.goResultPage(true) this.goResultPage(false);
goResultPage(_type) {
this.paypalResultStatus = true;
this.paypalResultType = _type;
},
// paypal结果上报
async paypalReport(_this) {
//上报接口参数
const paramsReport = {
id: _this.paypalRespond?.id, // 外部支付订单ID
payPalOrderId: _this.paypalRespond?.payPalOrderId, // PayPal Order ID
result: _this.paypalResultType?1:2, // 支付结果:1-成功;2-取消
};
// console.log("上报的参数---", paramsReport);
await reportOrderNFTPaypal(paramsReport)
.then((resp) => {
// console.log("上报结果--", resp);
_this.reportOrder = resp?.data;
_this.handleClose(2)
_this.$emit('success');
return _this.reportOrder;
})
.catch((err) => {
// this.$notice.error(_this.$t('order_paypal_Report_fail',{var1:'Paypal'}));
this.$notice.error(_this.$t('account.order_payment_wait'));
});
},
// 初始化paypal组件
async initPaypal(_this) {
_this.$refs.paypalBtnBox.innerHTML = ''; // 清空元素内容
window.paypal
.Buttons({
style: {
layout: 'vertical',//按钮样式
color: 'gold',//颜色
shape: 'pill',//
label: 'checkout',//按钮文本
tagline: false //
},
// locale: 'zh_CN',//按钮的语言
async createOrder() {
// 创建
try {
//创建订单xgemBuyPaypal
const response = await xgemBuyPaypal(_this.paypalOrder)
.then((resp) => {
_this.paypalRespond = resp?.data;
// console.log("--paypal---resp", _this.paypalRespond);
return _this.paypalRespond;
})
.catch((err) => {
_this.$notice.error(err);
return Promise.reject(err);
});
const orderData = await response;
if (orderData?.payPalOrderId) {
return orderData?.payPalOrderId;
} else {
const errorDetail = orderData?.details?.[0];
const errorMessage = errorDetail
? `${errorDetail.issue} ${errorDetail.description} (${orderData.debug_id})`
: JSON.stringify(orderData);
throw new Error(errorMessage);
}
} catch (err) {
_this.$notice.error(err);
}
},
async onApprove(data, actions) {
// 用户支付回调
await actions.order.capture()
.then((details) => {
// 支付成功
let orderNumber,orderAmount;
// 订单id
orderNumber = details.id;
//订单支付的金额
orderAmount = details.purchase_units[0].amount.value;
_this.goResultPage(true)
// console.log('支付成功---1-',details, orderNumber,orderAmount);
}).catch((err)=>{
//支付失败
_this.goResultPage(false)
// console.log('支付失败----',err)
});
_this.paypalApprove(_this,data,actions)
},
onCancel: function(data) {
// 在付款取消时执行的操作
// console.log('在付款取消时执行的操作---',data)
},
onClick: function(data) {
// 在点击支付按钮时执行的操作
// console.log('在点击支付按钮时执行的操作---',data)
},
})
.render(_this.$refs.paypalBtnBox);
},
// paypal支付状态回调
async paypalApprove(_this,data,actions){
// console.log("paypal回调---", data, "-----", actions);
try {
const response = _this.paypalReport(_this);
const orderData = await response;
} catch (error) {
console.error(error);
}
},
// 加载paypal脚本
initScript(){
const setLoaded = ()=>{
// console.log('初始化--加载script')
}
// 在页面中创建script标签
const script = document.createElement("script");
// 给script标签加src 链接到paypal
// script.src = "https://www.paypal.com/sdk/js?client-id=YOU_CLIENT_id";
// 测试连接 沙盒
// script.src = "https://www.paypal.com/sdk/js?client-id=test&components=buttons,marks";
script.src = `https://www.paypal.com/sdk/js?client-id=${this.clientId}`;
script.addEventListener("load", setLoaded);
document.body.appendChild(script);
}
},
};
</script>
<style lang="scss" scoped >
.popup-paypal{
display: flex;
justify-content: center;
align-items: center;
padding: 50px 0;
}
.paypal-button-container-box{
width: 70%;
}
</style>
PaypalResult.vue
查看代码
<template>
<div>
<div style="font-size: 20px; margin:60px 20px; text-align: center;">
<img v-if="showBtn" style="width:46px;" src="" alt="" />
<img v-else style="width:46px;" src="" />
<p style="font-size:20px;color:#3F3F3F;">{{showBtn?'Success':'Failed'}}</p>
<ButtonAsync class="btn-hollow" :async="closeWindow"> {{ $t("common.message_done") }}</ButtonAsync>
</div>
</div>
</template>
<script>
import ButtonAsync from "@/components/ButtonAsync";
export default {
name: "PaypalResult",
components: {
ButtonAsync,
},
props: {
atype: Boolean,
},
data() {
return {
showBtn: false,// 成功失败
};
},
watch: {
atype: {
handler(val, oldVal) {
this.showBtn = val;
},
deep: true,
immediate: true,
},
},
created() {
},
async mounted() {
},
methods: {
closeWindow(){
this.showBtn = false;
this.$emit("closeEvent", this.showBtn); //发送给子类 自定义方法
return Promise.resolve();
},
},
};
</script>
<style lang="scss" scoped >
.btn-base{
margin-top: 20px;
width: 100%;
}
</style>
參考vue3接入paypal
标签:console,log,script,接入,paypal,vue2,data,id From: https://www.cnblogs.com/miangao/p/18063224