我有一个表格,人们可以为特定活动预订座位。
它实际上是一个WordPress插件。
当有人发送预订时,会正确发送电子邮件通知,并相应更新活动预订状态
问题是预订表格没有给出任何反馈。
一旦您点击“立即预订”,图形将继续加载,并且不会显示任何反馈,例如“预订已成功发送”或“表单中存在错误”,即使预订正确保存,双方都通过电子邮件通知。
我想这是一个JavaScript问题,Firebug控制台没有显示任何错误...
这是预订表格的代码来源:
$('#em-booking-form').submit( function(e){
e.preventDefault();
var em_booking_doing_ajax = false;
$.ajax({
url: EM.bookingajaxurl,
data:$('#em-booking-form').serializeArray(),
dataType: 'jsonp',
type:'post',
beforeSend: function(formData, jqForm, options) {
if(em_booking_doing_ajax){
alert(EM.bookingInProgress);
return false;
}
em_booking_doing_ajax = true;
$('.em-booking-message').remove();
$('#em-booking').append('<div id="em-loading"></div>');
},
success : function(response, statusText, xhr, $form) {
$('#em-loading').remove();
$('.em-booking-message').remove();
$('.em-booking-message').remove();
//show error or success message
if(response.result){
$('<div class="em-booking-message-success em-booking-message">'+response.message+'</div>').insertBefore('#em-booking-form');
$('#em-booking-form').hide();
$('.em-booking-login').hide();
$(document).trigger('em_booking_success', [response]);
}else{
if( response.errors != null ){
if( $.isArray(response.errors) && response.errors.length > 0 ){
var error_msg;
response.errors.each(function(i, el){
error_msg = error_msg + el;
});
$('<div class="em-booking-message-error em-booking-message">'+error_msg.errors+'</div>').insertBefore('#em-booking-form');
}else{
$('<div class="em-booking-message-error em-booking-message">'+response.errors+'</div>').insertBefore('#em-booking-form');
}
}else{
$('<div class="em-booking-message-error em-booking-message">'+response.message+'</div>').insertBefore('#em-booking-form');
}
}
$('html, body').animate({ scrollTop: $("#em-booking").first().offset().top - 50 }); //sends user back to top of form
//run extra actions after showing the message here
if( response.gateway != null ){
$(document).trigger('em_booking_gateway_add_'+response.gateway, [response]);
}
if( !response.result && typeof Recaptcha != 'undefined'){
Recaptcha.reload();
}
},
complete : function(){
em_booking_doing_ajax = false;
$('#em-loading').remove();
}
});
return false;
});
答案 0 :(得分:2)
如果将数据类型设置为json
而不是jsonp
,则表单似乎会更好。
通常,当您需要向另一个域进行AJAX查询时,您将使用jsonp,而在此实例中您没有这样做。