javascript - ClearTimeout 是否可以在超时到期但尚未获得执行机会的情况下清除超时?

标签 javascript jquery callback onclick settimeout

假设我有一个运行客户端的函数render,可能需要 100-1000 毫秒 我有一个函数fetch,它发出服务器请求,并在成功时清除渲染超时,然后以 100 毫秒的超时调用渲染。 我有一个按钮,onclick,再次清除渲染超时,然后以 100 毫秒的超时调用渲染。

我发现,当我多次尝试单击该按钮时,并且如果发出了许多服务器请求,则只有第一个和最后一个响应会按预期进行渲染。 但这能保证吗?我可以放心地依赖它吗?

任何让我放心或告诉我陷阱的链接将不胜感激。 我经历过this 我知道无论如何,如果发生任何异步事件,它只会在第一次执行空闲时排队并执行,但我对队列中应该包含什么内容的决定感到困惑因为这是由浏览器完成的?

最佳答案

我很难找到好的源代码,因此我尝试在浏览器中运行此脚本。

var doItLater = function () {
    alert("I did it!");
};

window.onload = function () {
    // set a timeout to execute immediately
    var timeout = window.setTimeout(doItLater, 0);

    for (var i = 0; i < 1000000000; i++) {
        // waste some time
    }
    // The timeout has definitely triggered by now.
    // doItLater is queued up to execute as soon as
    // this function returns.

    clearTimeout(timeout); // wait, I changed my mind!
};

// Does doItLater get called?

而且它有效! clearTimeout() 会阻止 doItLater() 被调用,即使它已经被放入队列中。

顺便说一句,我绝对建议在渲染函数中使用 setTimeout() 来防止页面变得无响应。对于函数来说,1000 毫秒对于阻止事件循环来说太长了。 (例如,请参阅 here )

关于javascript - ClearTimeout 是否可以在超时到期但尚未获得执行机会的情况下清除超时?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23321377/

相关文章:

android - 可选回调

javascript - 新手: Need explanation of a Js function

javascript - 如何使用 JavaScript 检测页面上的 404 错误?

javascript - 如何在 knockout.js 中检测除更改事件之外的更改

javascript - 将当前元素作为参数传递给循环内的回调函数

Android : After Callback from Facebook, 我的主要 Activity 将调用哪个状态?

javascript - 何时将函数标记为异步

javascript - 如何指定一个样式不被JS中指定的样式覆盖

javascript - jQuery 窗口 .scroll 功能障碍

jquery - 使用黄金分割法调整元素高度