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事件循环的一个很好的解释

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...