Javascript 当jQuery返回错误时,如何在jQuery中重新发送ajax请求?
我的javascript中有一个ajax请求,它正在向Rails控制器发送数据。如果控制器发现数据与数据库中已有的信息重复,则返回“不可处理实体”错误 我想打开一个对话框,询问用户是否确定要插入重复信息。如果用户说是,我想向数据对象添加另一个密钥,然后重试请求。添加的键将是一个忽略重复检查并插入数据的标志Javascript 当jQuery返回错误时,如何在jQuery中重新发送ajax请求?,javascript,jquery,ruby-on-rails,ajax,Javascript,Jquery,Ruby On Rails,Ajax,我的javascript中有一个ajax请求,它正在向Rails控制器发送数据。如果控制器发现数据与数据库中已有的信息重复,则返回“不可处理实体”错误 我想打开一个对话框,询问用户是否确定要插入重复信息。如果用户说是,我想向数据对象添加另一个密钥,然后重试请求。添加的键将是一个忽略重复检查并插入数据的标志 $.ajax({ url: '/url', type: 'post', data: this.buildData(), success: fun
$.ajax({
url: '/url',
type: 'post',
data: this.buildData(),
success: function() {
bootbox.alert('Information added', function() {
Backbone.history.loadUrl();
}.bind(this)
);
}.bind(this),
error: function(jqXHR, textStatus, errorThrown) {
if(errorThrown === 'Unprocessable Entity') {
bootbox.confirm('Do it anyway?', function(confirm) {
if(confirm) {
/*Here I want to add another key to the data object and resend the request*/
}
}.bind(this)
);
}
}.bind(this)
});
我该怎么做,或者更好的是,有没有更好的方法来完成我想要完成的任务?首先,我确信有一些插件可以实现这一点 但是如果没有合适的插件,你可以一直这样做
function dispatchAjax( options ){
options = $.extend({},options);
var data = $.extend({}, this.buildData(), options.data );
$.ajax({ ... ,
error : function( ) { ....
if ( typeof(options.retry) == "function" ){
var retryFunc = options.retry;
options.retry = null;
options.data = { "extraKey":"extraValue"};
dispatchAjax( options );
}
});
}
给我一些时间来确保它正常运行,并给出完整的代码
您可能感兴趣的另一种方法是使用同步调用<代码>{“async”:false}在JQuery的ajax请求中
我知道这似乎违背了目的,但是我发现它对于服务器端验证非常有用-因此它可能适合您的需要,并且您不必处理复杂的处理程序,正如我上面所示,它将是这样的:
var result = dipatchRequest( options, /*async*/ false, /*ignore-duplicates*/ false );
if ( result.error && confirm(..) ){
dispatchRequest(options, true, true);
}
将ajax调用放入函数中。无论何时出现错误,请再次调用该函数。