如何在javascript中进行时间切片?

前端之家收集整理的这篇文章主要介绍了如何在javascript中进行时间切片?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
或ecmascript但我不知道它是如何实际发生的更多取决于确切的实施.

javascript在技术上是单线程的.

但如果我做了类似的事情

$myDIv.animate({
    height:"100px"
});

如果我这样做会有什么不同吗?

一个.

$myDIv.animate({
    height:"100px"
},null,my_cpu_heavy_function);

或B.

$myDIv.animate({
    height:"100px"
});
my_cpu_heavy_function();

因为在第二个动画中,动画会因为cpu函数而处理时间,所以动画的外观会受到影响,对吗?

那么,Javascript在同步代码块的末尾停止执行,还是在任何随机点切断一个块以允许另一个异步运行的块被处理?

解决方法

does it make any difference if i do A or B

是的,它会有所作为.

第二个版本并没有那么多争夺处理时间.它更像是my_cpu_heavy_function一旦开始就会占用所有处理时间,假设它是同步的.

换句话说,一旦一些同步代码开始,它就不会在完成之前结束,而不管可能被安排运行的任何定时异步代码.始终会强制异步代码等待同步代码完成.

那么将会发生的是动画将开始并执行其初始化,但随后my_cpu_heavy_function将立即启动,并阻止动画的其余部分直到完成.

猜你在找的JavaScript相关文章