JavaScript线程
2016-07-17 21:58
519 查看
JavaScript是单线程的,因此在单个脚本运行过程中,会阻塞其它代码的执行和页面的渲染。
一个例子:
结果:
f1最后执行,原因是浏览器把它加入到执行序列中,等到JS线程空闲时才会执行。
所以JS对DOM的操作也只有等到脚本执行完毕后才会在页面反应出来,所以setTimeout等定时函数就非常重要了,这是IFE的JS和树任务,要求将搜索过程以1s的间隔进行动画演示,最开始是直接在搜索到的条件判断里改变元素背景,但发现没有动画,因为在函数执行过程中无法渲染页面,后来将结果保存在数组里形成一个队列,然后用setTimeout间隔1s逐步执行数组的项,动画效果就有了,所以在编写动画效果时,要多多注意JS单线程特性。
一个例子:
function f1() { console.log("f1"); } function f2() { console.log("f2"); setTimeout(f1, 0); } function f3() { console.log("f3"); } for (var i = 0; i < 10; i++) { f2(); } f3();
结果:
f1最后执行,原因是浏览器把它加入到执行序列中,等到JS线程空闲时才会执行。
所以JS对DOM的操作也只有等到脚本执行完毕后才会在页面反应出来,所以setTimeout等定时函数就非常重要了,这是IFE的JS和树任务,要求将搜索过程以1s的间隔进行动画演示,最开始是直接在搜索到的条件判断里改变元素背景,但发现没有动画,因为在函数执行过程中无法渲染页面,后来将结果保存在数组里形成一个队列,然后用setTimeout间隔1s逐步执行数组的项,动画效果就有了,所以在编写动画效果时,要多多注意JS单线程特性。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解