美文网首页
js运行机制

js运行机制

作者: 事在人为s | 来源:发表于2020-04-09 20:57 被阅读0次
console.log(1);
setTimeout(function() {
    console.log(2)
}, 0)
console.log(3);
//结果: 1 3 2
console.log("A");
setTimeout(() => {
    console.log("B");
})
while (true) {

}
//结果: A
//浏览器的定时器会记住setTimeout语句,等时间到了会放入异步队列中
for (var i = 0; i < 4; i++) {
    setTimeout(function() {
        console.log(i);
    }, 1000)
}
//结果:  4 4 4 4

如何理解js的单线程

一个时间之内js只能干一件事

什么是任务队列和Event Loop

同步任务,异步任务
异步任务放入时间和执行时间:遇到setTimeout语句,识别为异步任务,不会在运行栈中执行,拿走等时间到了,放入任务队列中,同步任务执行完后,监听任务队列中,有就执行,如此循环就是事件循环


js事件循环

异步任务

  • setTimeout和setInterval
  • DOM事件
  • ES6中的Promise

总结

  • 理解js的单线程的概率
  • 理解任务队列
  • 理解Event Loop
  • 理解哪些语句会放入异步任务队列
  • 理解语句放入异步任务队列的时机

相关文章

  • 最全js运行机制

    js运行机制

  • js new 运行机制

    js手札--js中new到底做了些啥JS核心系列:理解 new 的运行机制深入理解 Javascript 运行机制及原型

  • 浅析Vue.nextTick()原理

    1、为什么用Vue.nextTick() 首先来了解一下JS的运行机制。 JS运行机制(Event Loop) J...

  • 运行机制,宏任务 与 微任务

    运行机制: JS 的本质是单线程执行 事件队列:同步任务,异步任务() 运行机制 1,JS 的本质是单线程执行 单...

  • 前端知识点

    JS 1. 事件循环 「硬核JS」一次搞懂JS运行机制[https://juejin.cn/post/684490...

  • js运行机制

    js运行机制 在日常面试求职中,不免会做几道面试题,这面试题中往往会遇到js执行输出顺序,而这运行机制是我们每个前...

  • Event Loop

    关于浏览器的多进程,JS单线程等涉及浏览器整体运行机制、浏览器内核、JS运行机制,请看这篇文章,全是干货,什么时候...

  • JS的运行机制

    title: JS的运行机制date: 2018-12-28 11:02:52tags: js 为什么JavaSc...

  • JavaScript执行机制、Event Loop

    一、运行机制 JavaScript是单线程运行机制。 为什么JavaScript是单线程?单线程就是说,js在同一...

  • JS运行机制

    JS运行机制 如果一个文档流中包含多个script代码段(用script标签分隔的js代码或引入的js文件),运行...

网友评论

      本文标题:js运行机制

      本文链接:https://www.haomeiwen.com/subject/nzbhmhtx.html