以下是通过Stripe.js提交信用卡表单的通用代码。我需要将其放入我粘贴在下面的Backbone视图中:
// Add Submit Btn Event Listener and Stripe Token Generator from fields
jQuery(function($) {
$('#payment-form').submit(function(event) {
event.preventDefault();
var $form = $(this);
// Disable the submit button to prevent repeated clicks
$form.find('button').prop('disabled', true);
Stripe.createToken($form, stripeResponseHandler);
// Prevent the form from submitting with the default action
return false;
});
}); // End jQuery random function
var stripeResponseHandler = function(status, response) {
var $form = $('#payment-form');
if (response.error) {
// Show the errors on the form
$form.find('.payment-errors').text(response.error.message);
$form.find('button').prop('disabled', false);
} else {
// token contains id, last4, and card type
var token = response.id;
// Insert the token into the form so it gets submitted to the server
$form.append($('<input type="hidden" name="stripeToken" />').val(token));
// and submit
$form.get(0).submit();
}
}; // End stripeResponseHandler
我试图将其纳入Backbone View(不工作):
WhiteDeals.Views.ProgramPayment = Backbone.View.extend({
initialize: function() {
_.bindAll(this);
},
events: {
"submit form#payment-form": "createStripeToken"
},
createStripeToken: function(event) {
event.preventDefault();
var $form = $(this);
// Disable the submit button to prevent repeated clicks
$form.find('button').prop('disabled', true);
Stripe.createToken($form, stripeResponseHandler);
// Prevent the form from submitting with the default action
return false;
}, // createStripeToken
stripeResponseHandler: function(status,response) {
var $form = $('#payment-form');
if (response.error) {
// Show the errors on the form
$form.find('.payment-errors').text(response.error.message);
$form.find('button').prop('disabled', false);
} else {
// token contains id, last4, and card type
var token = response.id;
// Insert the token into the form so it gets submitted to the server
$form.append($('<input type="hidden" name="stripeToken" />').val(token));
// and submit
$form.get(0).submit();
}
},
render: function () {
var dealProgram = this.model.toJSON()
this.$el.html(JST['program/payment']({ dealProgram: this.model.toJSON() }));
// Show Payment Modal
$('#payment-modal').modal({
show: true,
keyboard: true,
backdrop: true
})
return this;
}
});
答案 0 :(得分:3)
上下文不一样。当您在视图中使用events
对象绑定侦听器时,上下文将自动绑定到视图本身。
变化:
var $form = $(this);
到
var $form = this.$('#payment-form');