Vue компонент с полосой JS v3
Я использую компонент Vue для своей формы оформления заказа.
Файл stripe js (v3) был включен в раздел заголовка.
Форма была в компоненте
Этот компонент имеет два раздела. Одним из них является получение реквизитов платежа от пользователя, а другим - предоставление данных карты.
<template>
<div class="payment_form">
<div id="payment_details" v-if="showPaymentDetails">
<!-- User input goes here. Like username phone email -->
</div>
<div id="stripe-form" v-if="showStripeForm">
<form action="/charge" method="post" id="payment-form" @submit.prevent="createStripeToken()">
<div class="form-row">
<label for="card-element">
Credit or debit card
</label>
<div id="card-element">
<!-- a Stripe Element will be inserted here. -->
</div>
<!-- Used to display Element errors -->
<div id="card-errors" role="alert"></div>
</div>
<button>Submit Payment</button>
</form>
</div>
</div>
</template>
<script>
import { Validator } from 'vee-validate';
export default {
data() {
return {
stripeToken: '',
showPaymentDetails: true,
showStripeForm: true,
}
},
created() {
},
methods: {
validateForm() {
self = this;
this.$validator.validateAll().then(result => {
if (result) {
// eslint-disable-next-line
alert('From Submitted!');
console.log(this.$data);
axios.post('/data',{
name:this.name,
})
.then(function (response) {
self.showStripeForm = true;
console.log(response);
})
.catch(function (error) {
console.log(error);
});
return;
}
});
},
createStripeToken(){
var form = document.getElementById('payment-form');
form.addEventListener('submit', function(event) {
event.preventDefault();
window.stripe.createToken(card).then(function(result) {
if (result.error) {
// Inform the user if there was an error
var errorElement = document.getElementById('card-errors');
errorElement.textContent = result.error.message;
} else {
// Send the token to your server
console.log(result.token);
}
});
});
},
initStripe(){
window.stripe = Stripe('stripe_test_key_here');
var elements = stripe.elements();
var style = {
base: {
// Add your base input styles here. For example:
fontSize: '16px',
lineHeight: '24px'
}
};
// Create an instance of the card Element
window.card = elements.create('card', {style: style});
// Add an instance of the card Element into the `card-element` <div>
window.card.mount('#card-element');
}
},
mounted() {
this.initStripe();
setTimeout(function () {
this.showStripeForm = false;
},2000);
}
}
</script>
Я пытаюсь загрузить полосу формы при загрузке страницы и пытаюсь отключить элемент через showStripeForm.
Но vue сбросил загруженную форму карты полосы с сервера полосы и сохранил ее в исходное состояние.
Так что я не могу вызвать полосу на обратном вызове Axios.
Я не хочу использовать полосу извлечения и полосу js v1(после этой версии получение данных в вашей форме устарело).
1 ответ
В mounted
, Изменить setTimeout
обратный вызов функции стрелки, в противном случае, this
будет указывать на Window
вместо Vue
,
mounted() {
setTimeout(() => {
this.showStripeForm = false
}, 2000)
}
Кроме того, способ доступа к DOM не так хорош. Вы могли бы использовать ref
на элемент DOM, который вы хотите использовать в своем коде. Например:
<form action="/charge" method="post" ref="payment-form" @submit.prevent="createStripeToken()">
Затем получить доступ к нему из $refs
как это:
var form = this.$refs['payment-form']
/*
Same result as document.getElementById('payment-form')
but without using an id attribute.
*/