javascript – history.back()之后的代码会发生什么?

前端之家收集整理的这篇文章主要介绍了javascript – history.back()之后的代码会发生什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有以下代码
window.history.back();
myFunction(10);

> history.back()是阻塞/非阻塞呼叫吗?
>是否可以确保myFunction()将被执行?或者不会被执行?
>这是一个可能的竞争条件,其中history.back()异步发生
是否调用myFunction()取决于不可控事件的时间?

解决方法

spec说历史.背面 queues a task.

因此,实际的历史操作代码(JS实现的内部代码)将在主event loop的下一次运行期间执行.您对myFunction的调用在当前执行循环中同步执行,因此它将始终在兼容环境中执行.

但是,只保证myFunction中的同步代码可以执行.考虑这个例子:

function myFunction() {
  console.log('synchronous');
  debugger

  setTimeout(function() {
    console.log('async');
    debugger
  })
}

window.history.back();
myFunction();

始终会遇到第一个调试器语句.第二个,使用setTimeout延迟到将来的事件循环tick,不会.

This article是JavaScript事件循环的一个很好的解释

猜你在找的JavaScript相关文章