如何触发PayPal Checkout按钮的点击?
我们的网站除了信用卡支付外,还将接受PayPal付款,我决定为客户放置单选按钮,以选择客户支付方式,并提供PayPal Checkout按钮:
PayPal Checkout按钮本身会打开PayPal安全窗口,其余部分都正常工作。当客户点击第一个单选按钮时,我想再次打开PayPal安全窗口,即触发PayPal Checkout按钮上的点击事件。
如果按钮本身出现在iframe中,我无法跨域触发该按钮的点击事件。是否有任何方法可以触发Checkout按钮的点击事件?
以下是HTML代码:
以下是HTML代码:
<html>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
<script src="https://www.paypalobjects.com/api/checkout.js"></script>
<script type="text/javascript" src="paypal.js">
</script>
<body>
<div>
<span style="vertical-align: 50%"><input id="rd" name="aaa" type="radio"/></span>
<div id="paypal-button-container" style="display: inline-block"></div><hr/>
<input id="rd1" name="aaa" type="radio"/>
</div>
</body>
</html>
以及Javascript代码:
// paypal.js
// Render the PayPal button
$(function(){
paypal.Button.render({
// Set your environment
//TODO: Dynamically provide sandbox or production
env: 'sandbox', // sandbox | production
// PayPal Client IDs - replace with your own
// Create a PayPal app: https://developer.paypal.com/developer/applications/create
//TODO: Dynamically provide clientID
client: {
sandbox: 'ZZZZZZ',
production: '//TODO: Provide this later'
},
// Wait for the PayPal button to be clicked
payment: function() {
// Make a client-side call to the REST api to create the payment
return paypal.rest.payment.create(this.props.env, this.props.client, {
transactions: [
{
amount: { total: '13.10', currency: 'USD' }
}
]
});
},
// Wait for the payment to be authorized by the customer
onAuthorize: function(data, actions) {
return actions.payment.get().then(function(paymentData) {
$('#paypal-button-container').style.display = 'none'; //hide button
//TODO: Show user payment details
//TODO: Create input hidden fields and set payerID, paymentID, etc..for later authoriza/capture
});
},
onClick: function(){
$('#rd').trigger('click');
},
}, '#paypal-button-container');
});
编辑:作为一个工作示例,我建议使用这个网站,但这与我需要的略有不同 https://developer.paypal.com/demo/checkout/#/pattern/mark
window.open
异步执行(不会立即在按钮点击时执行),从而导致浏览器的弹出窗口拦截程序阻止它。为什么要使用iframe呢?除了允许我们呈现完美的按钮外,它还解决了一个恶心的问题,在IE中你几乎不能在不同域之间的父窗口和弹出窗口之间发送消息。因此,它最终成为了确保一切无缝工作的最少hacky的方式。 - bluepnume