由于回调结构中可能存在错误,无法使超时工作
Cannot get timeout to work due to possible errors in callback structure
我正试图使用以下代码在一次按键操作中两次调用服务器进程。我的要求是我需要尝试两次,并向用户更新我正在重试的信息。如果其中一次尝试成功,我会发出成功的信息,如果两次都失败了,我会告诉他们"再试一次"。
按照编码,以下代码有效。唯一的问题是,我希望每条消息都显示一秒钟,以便可以阅读。
我尝试过setTimeout(1000)和delay(1000)的每一种组合,但要么没有效果,要么就挂起了。我怀疑我的回调结构存在逻辑缺陷。有人能告诉我我做错了什么吗?
$(".infoMessage").text("Starting Open Process...");
var deferred = openATMRPC.openATMFirst();
deferred.addCallback(function(result){
if (result == "false") {
$(".infoMessage").text("Attempting Second try...");
var insideDeferred = openATMRPC.openATMSecond();
insideDeferred.addCallback(function(result) {
if (result == "false") {
$(".infoMessage").text("Try Again Later");
} else {
$(".infoMessage").text("Success 2");
}
})
} else if(result == "true"){
$(".infoMessage").text("Success 1");
}
}
)
注意:无论成功与否,我的服务器进程都会返回一个字符串"true"或"false"。
使用jQuery.Deferred()尝试此模式
$(function () {
$(".infoMessage").text("Starting Open Process...");
// included `trueFalse` argument , here , to display flow of results
// not certain if `openATMRPC.openATMFirst()` ,
// `openATMRPC.openATMSecond()` returns a `promise` object ?
// utilized same function applied to both `deferred` and `insideDeferred`
var deferred = function(trueFalse) {
// return value from response as `deferred.promise`
// within `setTimeout` , after `1000` ms (one second)
return new $.Deferred(function (dfd) {
setTimeout(function () {
$.post("/echo/html/", {
html: trueFalse
})
// `deferred.always` utilized here ,
// to catch either `success` or `fail` ,
// not certain about `error` (`fail`) callbacks ?
.always(function (data) {
dfd.resolve(data)
})
}, 1000);
// return `deferred.promise()` ,
// e.g., "true" , or "false"
return dfd.promise()
})
};
// `deferred()` function called with `"false"` argument
deferred("false").done(function (result) {
if (result == "false") {
$(".infoMessage").text("Attempting Second try...");
// `insideDeferred` = `deferred()` called with `"true"` argument
var insideDeferred = deferred("true");
insideDeferred.done(function (result) {
if (result == "false") {
$(".infoMessage").text("Try Again Later");
} else {
$(".infoMessage").text("Success 2");
}
})
} else if (result == "true") {
$(".infoMessage").text("Success 1");
}
})
});
jsfiddlehttp://jsfiddle.net/guest271314/vpy207t9/
$(function () {
$(".infoMessage").text("Starting Open Process...");
var deferred = function(trueFalse) {
return new $.Deferred(function (dfd) {
setTimeout(function () {
dfd.resolve(trueFalse)
}, 1000);
return dfd.promise()
})
};
deferred("false").done(function (result) {
if (result == "false") {
$(".infoMessage").text("Attempting Second try...");
var insideDeferred = deferred("true");
insideDeferred.done(function (result) {
if (result == "false") {
$(".infoMessage").text("Try Again Later");
} else {
$(".infoMessage").text("Success 2");
}
})
} else if (result == "true") {
$(".infoMessage").text("Success 1");
}
})
})
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
<div class="infoMessage"></div>
相关文章:
- Jquery菜单操作不稳定,定位不正确,存在一般错误
- 未捕获的类型错误:无法读取属性'name'即使它存在,也无法定义
- 是否存在Javascript Liferay Service库的文档?如何处理错误情况
- 动态代码中存在系统应用程序地址错误
- 对象为null或IE9中存在未定义错误
- ArrayList中存在语法错误
- "所请求的名称已经作为不同类型的“”存在;HTTP 409响应错误
- 如果文件不存在,fs.watch是否有错误处理程序
- 如何仅在存在最小值和最大值时才显示错误消息
- Extjs 抛出错误“请验证文件是否存在”
- 打字稿错误:P roperty'包含'在类型'元素'上不存在
- 错误 TS2339:类型“{}”上不存在属性“forEach”
- ajax请求返回me“;错误404”;即使资源存在
- 开箱即用的Light Switch HTML应用程序在IE9中存在null错误
- JavaScript setInterval函数:是否存在错误
- 这个get方法似乎可以工作,但控制台中存在错误
- JSONP跨原点错误'不存在Access Control Allow Origin标头'
- appendChild上的错误-试图在不存在节点的上下文中引用该节点
- Simple Javascript if语句中存在语法错误
- 如果字符串中存在错误,请检查数组中的char