javascript - SetTimeout 从不调用函数

标签 javascript

我创建了一个循环来模拟长时间运行的操作。在这里:

var b1, b2;
b1 = true;
b2 = false;
while (b1) {
    if (!b2) {
        setTimeout(function() => {
            b1 = false;
        }, 1000);
       b2 = true;
     }
}

关于为什么 b1 = true; 永远不会发生的任何想法?

最佳答案

setTimeout 仅安排函数在 n 秒后执行。在该时间段过去后,该函数将以与任何其他函数相同的方式放入线程执行堆栈。

在这种情况下,超时函数将不会中断 while 循环的执行。它将在主线程执行完成后执行……所以永远不要。

您可以查看定时器的 HTML5 规范草案 here .

关于javascript - SetTimeout 从不调用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28439458/

相关文章:

javascript - 如何在 react 手势画廊制作的幻灯片的幻灯片上添加按钮或文本

javascript - JavaScript 中的 LinkedList,如何将更改附加到列表?

javascript - 为什么将javascript文件包含在函数中?

javascript - Jquery Fadeout fadein 与 li 元素问题

javascript - Uncaught ReferenceError : function is not defined with onclick

javascript - 根据格式过滤数组项

javascript - 如何在移动 View Owl Carousel 中运行jump(n)幻灯片?

javascript - 使用对象创建二维数组 - Javascript

javascript - 将 html 表格导出为 word 文件并更改文件方向

javascript - 用于验证文本区域输入的正则表达式,该输入必须是由换行符分隔的 URL