我试图将Stripe元素实现到我的rails应用程序中,但我似乎无法正确包含stripe.js。这是我的application.html
<%= tag :meta, name: "stripe-key", content: Figaro.env.stripe_publishable_key %>
<script type="text/javascript" src="https://js.stripe.com/v3/"</script>
<script type="text/javascript" src="https://js.stripe.com/v2/"></script>
var stripe = Stripe($("meta[name='stripe-key']").attr("content"))
var elements = stripe.elements();
var card = elements.create('card', {
style: {
base: {
iconColor: '#999',
color: '#505652',
lineHeight: '40px',
fontWeight: 300,
fontFamily: 'Helvetica Neue',
'::placeholder': {
color: '#CFD7E0',
},
},
}
});
// Add an instance of the card UI component into the `card-element` <div>
card.mount('#card-element');
<form action="/charge" method="post" id="payment-form">
<div class="form-row">
<label for="card-element">
Credit or debit card
</label>
<div id="card-element">
</div>
<div id="card-errors"></div>
</div>
<button>Submit Payment</button>
</form>
每次加载页面时,我都会在控制台Uncaught ReferenceError: Stripe is not defined - STRIPE ERROR
中收到此错误消息。我认为它与我加载stripe.js的方式有关,但我不确定?
答案 0 :(得分:9)
我怀疑Stripe.js正在加载你自己的javascript之后发生了什么。尝试在标题中将Stripe.js移动到您自己的javascript之上。
答案 1 :(得分:1)
可能会迟到,但是如果其他人遇到相同的问题,只需在您的
中添加以下内容ColumnCount
知道他们建议尽快迁移到v3。
答案 2 :(得分:1)
Stripe.js现在在所有其他脚本之后加载,这意味着它不再立即可用。我已经将脚本从正文标签移到了头部标签。
<head>
<script src="https://js.stripe.com/v3/"></script>
</head>
答案 3 :(得分:0)
您可能会使用类似的
<%= javascript_include_tag 'https://js.stripe.com/v3/', 'data-turbolinks-track': 'reload' %>
答案 4 :(得分:0)
让我失望的是他们的文档有教程,他们跳过了 Stripe 库的初始化。因此,如果您从这些教程之一开始并尝试他们的示例代码,它将无法正常工作。
相反,您需要在脚本中的某处添加这一行:
var stripe = Stripe("your_stripe_publishable_key");