По умолчанию при использовании полосы в всплывающем окне ( stripe-checkout ) поле электронной почты отправляется как card[name]
.
Но когда я использую элементы полосы (поля полосы каквстроенные поля, без всплывающего окна) поле электронной почты отсутствует, и если я добавлю свое собственное поле электронной почты, оно будет игнорироваться полосой.Это приводит к добавлению клиента на полосу без электронной почты, что затрудняет идентификацию одного клиента с другим.
Как я могу изменить этот код для передачи электронной почты на полосу?демо: https://jsfiddle.net/ywain/foc0L56q/
<script src="https://js.stripe.com/v3/"></script>
<body>
<form action="//httpbin.org/post" method="POST">
<input type="hidden" name="token" />
<div class="group">
<label>
<span>Card</span>
<div id="card-element" class="field"></div>
</label>
</div>
<div class="group">
<label>
<span>Email</span>
<input id="email" name="email" class="field" placeholder="jane.doe@example.com" />
</label>
</div>
<button type="submit">Pay $25</button>
<div class="outcome">
<div class="error"></div>
<div class="success">
Success! Your Stripe token is <span class="token"></span>
</div>
</div>
</form>
</body>
var stripe = Stripe('pk_test_6pRNASCoBOKtIshFeQd4XMUh');
var elements = stripe.elements();
var card = elements.create('card');
card.mount('#card-element');
function setOutcome(result) {
var successElement = document.querySelector('.success');
var errorElement = document.querySelector('.error');
successElement.classList.remove('visible');
errorElement.classList.remove('visible');
if (result.token) {
// In this example, we're simply displaying the token
successElement.querySelector('.token').textContent = result.token.id;
successElement.classList.add('visible');
// In a real integration, you'd submit the form with the token to your backend server
var form = document.querySelector('form');
form.querySelector('input[name="token"]').setAttribute('value', result.token.id);
form.submit();
} else if (result.error) {
errorElement.textContent = result.error.message;
errorElement.classList.add('visible');
}
}
card.on('change', function(event) {
setOutcome(event);
});
document.querySelector('form').addEventListener('submit', function(e) {
e.preventDefault();
stripe.createToken(card).then(setOutcome);
});