正在中止JavaScript setTimeout函数
Aborting a JavaScript setTimeout function
标题可能有误导性,但它本质上是我需要完成的。
我有一个AJAX"加载"文本,如果服务器的响应时间超过15秒,我想更新它。
这是代码:
$(".loader").html('Loading');
$(".loader").show();
setTimeout(function () {
if ($('.loader').is(":visible")) {
$(".loader").html('Click <a href="javascript:location.reload()">here</a> to reload.</span>');
}
}, 15000);
有更好的方法吗?当我最终调用$(".loader").hide();
时,我希望中止setTimeout
计数器。有可能吗?
当然。setTimeout
返回一个值,您可以将该值传递给clearTimeout
以停止超时。
var handle = setTimeout(function () {
alert("Oh noes, I ran!")
}, 5000)
clearTimeout(handle)
您可以使用clearTimeout函数:
$(".loader").html('Loading');
$(".loader").show();
var timerId= setTimeout(function () {
if ($('.loader').is(":visible")) {
$(".loader").html('Click <a href="javascript:location.reload()">here</a> to reload.</span>');
}
}, 15000);
$(".stop").click(function () {
clearTimeout(timerId);
$(".loader").html("done");
});
看看这把小提琴:http://jsfiddle.net/KaNUP/
我建议缩短周期(1秒),并在您调用的函数内递增计数器。然后,您可以在成功加载或计数器阈值时退出,以较早者为准。
相关文章:
- setTimeout函数能否在其前面的代码执行之前激发
- JS:setTimeout函数的UI计数
- Jasmine:测试setTimeout函数会抛出一个错误
- Javascript/Jquery setTimeout 函数不适用于长 html
- 如何让 setTimeout 函数运行,然后停止使用循环
- 有没有办法覆盖 setTimeout 函数,使其使用微秒而不是毫秒
- setTimeout函数的精确计时
- Javascript-为什么不是't此setTimeout函数正在工作
- 阻止页面重新加载时的setTimeout函数
- 2 setTimeout函数第一个清除第二个javascript
- 如何在 setInterval/setTimeout 函数中按名称调用函数
- Javascript SetTimeOut函数不知怎么不起作用
- Javascript setTimeOut 函数与 .net 中 Windows 应用程序的计时器不匹配
- Javascript setTimeout 函数保持运行
- 当 ajax 返回 1 时如何删除 setTimeout 函数
- setTimeout 函数比它应该的更快
- Javascript:我的setTimeout函数由于第三方而不起作用
- 如何或在哪里将javascript settimeout函数添加到CSS垂直下拉菜单
- 在 javascript 对象中使用方法的值以在 setTimeout 函数中使用
- 如何阻止此 setTimeout 函数运行