为什么需要异步?why?来看一段代码。
问题1:
for(var i=0;i<100000;i++){ } alert('hello world!!!');
这段代码的意思是执行100...次后再执行alert,这样带来的问题是,严重堵塞了后面代码的执行,至于为什么,主要是因为JS是单线程的。
问题2:
我们通常要解决这样一个问题,如果我们需要在head里面加入script代码的话,一般会将代码写在window.onload
里面(如果操作了dom的话),你有没有想过,为什么要加window.onload
?原因就是你在操作dom的时候script后面的html代码浏览器还没有开始加载,结果人家还没有出生你就想着去娶她,这可能吗?当然不可能,加上window。onload
之所以可以是因为,window.onload
里面的代码是在文档全部加载完毕后执行的,也就相当于异步。
问题3:
有时候页面并不需要一次性把所有的代码都加载,更多的时候我们是按照某个需求才去加载某段代码的。
什么是单线程?
你可以这样理解单线程就是代码一段一段的执行,先执行前面的,前面的执行完了再执行后面的。
那JS中有哪些是异步的呢?
我相信这个东西,几乎都用烂了,它就是setTimeout/setInterval当然还有Ajax,Ajax异步我相信大家都知道,当然也可以同步但没人那么去做,但是对于setTimeout和setInterval是异步可能有些小伙伴不同了解,下面说说为什么说setTimeout是异步的。
setTimeout(function(){ console.log(0); },0) console.log(1); // 1 // 0
运行这段代码后先打印的是1,而不是0,有些小伙伴是不是开始迷惑了,这里我们虽然给setTimeout设置的是0秒后执行console.log(0)
,但是这个setTimeout很特别,因为它是异步的,我们先抛开这里为什么打印的是1然后才是0,先来聊聊什么是异步。
什么是异步?
比方说有些饭店你去吃饭需要提前预定,等其他人吃完你才能去,因此在其他人吃饭的时候你可以去干其他的事情,等其他人吃完了会有人来通知你,于是你可以去了,那么对于代码来说,如ajax,你定义了一个回调方法,这个回调方法并不会当时就去执行,而是等待服务器响应完成之后才会去执行这段代码。
我们回到前面那段setTimeout身上,它的工作原理是这样的,当你定义setTimeout那一刻起(不管时间是不是0),js并不会直接去执行这段代码,而是把它扔到一个事件队列里面,当页面中所有同步任务都干完了以后,才会去执行事件队列里面的代码。什么是同步,除了异步代码就是同步—_—。
JS怎么实现异步?
1.利用setTimout实现异步
setTimeout(function(){ console.log(document.getElementByTagName('body')[0]); },0)
但是setTimeout有些小小的问题,就是时间不精确,如果你想更快的执行这段代码我们可以使用html5提供的一个函数。
requestAnimationFrame(function(){ console.log(document.getElementByTagName('body')[0]); })
requestAnimationFrame和setTimeout的区别就在于requestAnimationFrame比setTimeout更快执行,因此很多人用requestAnimationFrame来制作动画。
2.动态创建script标签
var head = document.getElementByTagName('head')[0]; var script = document.createElement('script'); script.src = '追梦子.js'; head.appendChild('script');
3.利用script提供的defer/async
<script src="/UploadFiles/2021-04-02/xx.js">defer:当页面加载完毕以后才去执行这段代码。
<script src="/UploadFiles/2021-04-02/xx.js">async:异步执行script代码
不过异步也是缺点的,比如下面这段代码:
正常代码:
try{ throw new Error('hello world'); }catch(err){ console.log(err); } // Error: hello world(…)异步代码:
try{ setTimout(function(){ throw new Error('hello world'); },0) }catch(err){ console.log(err); } // ReferenceError: setTimout is not defined(…)可以发现catch里面的代码并没有执行,也就是说try无法捕获异步里面的代码。
总结
关于JS中的异步以及如何异步到这就基本结束,关于JS的异步算是老生常谈了,但是还是希望本文的内容对大家能有一些帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 华少翌.2005-华少翌【中唱艺能】【WAV+CUE】
- 群星《十二女声Ⅱ》[WAV/CUE/分轨][527MB]
- 大自然音乐系列《漫步在山裡》[WAV/CUE/分轨][502.8MB]
- 大自然音乐系列《星光夜语》[WAV/CUE/分轨][453.3MB]
- 史依弘《史依弘交响乐京剧演唱专辑HQ》头版限量编号[WAV+CUE]
- 曼丽2020《女人三十风继续吹》HQCD[WAV+CUE]
- 曼丽2021《女人三十2雾之恋》HQCD[WAV+CUE]
- 隔壁老樊.2019-我曾【好听音乐】【FLAC分轨】
- 高林生.1993-牵挂你的人是我【白天鹅】【WAV+CUE】
- 洪卓立.2012-找个懂我的女孩(国专)【英皇娱乐】【WAV+CUE】
- 曼丽2022《女人三十3晚秋》HQCD[WAV+CUE]
- 曼丽2018《女人三十4冬天》HQCD[WAV+CUE]
- 柏菲-《好歌30年壹》限量开盘母带ORMCD[低速原抓WAV+CUE]
- 大自然音乐系列《水舞》[WAV/CUE/分轨][424.3MB]
- 大自然音乐系列《星光夜语》[WAV/CUE/分轨][453.3MB]