我有一张包含发票的表,这意味着有多行,每行包含一个表单,用户可以在其中提交付款,如何使用jquery拦截正确的表单提交?
现在我可以拦截第一个表单的提交但我需要这个更通用,并允许我拦截任何表单的提交。
感谢您的帮助,谢谢您的时间。
我目前的代码:
payment.blade.php
<form action="{{'/users/payment'}}" method="post" id="checkout-form">
checkout.js
$(document).ready(function() {
console.log("Checkout.js is running!");
Stripe.setPublishableKey('...');
var $form = $('form:last');
console.log($form);
$form.submit(function (event) {
console.log("form submit event clicked");
$('charge-error').addClass('hidden');
$form.find('button').prop('disabled', true);
if ($('#paymentMethod').val() == 'Saved Card') {
console.log("reaching if statement");
// No new card is used so just submit the form.
$form.get(0).submit();
return false;
} else {
console.log("reaching else statement");
console.log($('#card-number').val());
Stripe.card.createToken({
number: $('#card-number').val(),
cvc: $('#card-cvc').val(),
exp_month: $('#card-expiry-month').val(),
exp_year: $('#card-expiry-year').val()
}, stripeResponseHandler);
return false;
}
});
function stripeResponseHandler(status, response) {
if (response.error) {
console.log("reaching error statement");
$('#charge-error').removeClass('hidden');
$('#charge-error').text(response.error.message);
$form.find('button').prop('disabled', false);
} else {
console.log("reaching successful response statement");
var token = response.id;
// Insert the token into the form so it gets submitted to our local server:
$form.append($('<input type="hidden" name="stripeToken" />').val(token));
// Submit the form:
$form.get(0).submit();
}
}
});
答案 0 :(得分:2)
只需更改表单选择器
即可var $form = $("form");
然后
$form.submit(function(){
//Every form submit will trigger this function
});
访问表单的子元素
$form.submit(function(){
$this = $(this);
var number = $this.find('#card-number').val(),
cvc = $this.find('#card-cvc').val(),
exp_month = $this.find('#card-expiry-month').val(),
exp_year = $this.find('#card-expiry-year').val();
});