zoukankan      html  css  js  c++  java
  • js异步

    为什么需要异步?why?来看一段代码。

    问题1:

    1
    2
    3
    4
    5
    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是异步的。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    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实现异步    

    1
    2
    3
    setTimeout(function(){
      console.log(document.getElementByTagName('body')[0]);
    },0)

      但是setTimeout有些小小的问题,就是时间不精确,如果你想更快的执行这段代码我们可以使用html5提供的一个函数。  

    1
    2
    3
    requestAnimationFrame(function(){
      console.log(document.getElementByTagName('body')[0]);
    })

      requestAnimationFrame和setTimeout的区别就在于requestAnimationFrame比setTimeout更快执行,因此很多人用requestAnimationFrame来制作动画。

      

      2.动态创建script标签  

    1
    2
    3
    4
    var head = document.getElementByTagName('head')[0];
    var script = document.createElement('script');
    script.src = '追梦子.js';
    head.appendChild('script');

       3.利用script提供的defer/async

    1
    <script src="xx.js" defer></script>

      defer:当页面加载完毕以后才去执行这段代码。

    1
    <script src="xx.js" async></script>

      async:异步执行script代码

      

    不过异步也是缺点的,比如下面这段代码:

      正常代码:    

    1
    2
    3
    4
    5
    6
    7
    try{
      throw new Error('hello world');
    }catch(err){
      console.log(err);
    }
     
    // Error: hello world(…)

      异步代码:  

    1
    2
    3
    4
    5
    6
    7
    8
    9
    try{
      setTimout(function(){
        throw new Error('hello world');
      },0)
    }catch(err){
      console.log(err);
    }
     
    // ReferenceError: setTimout is not defined(…)

    可以发现catch里面的代码并没有执行,也就是说try无法捕获异步里面的代码。

    总结

    关于JS中的异步以及如何异步到这就基本结束,关于JS的异步算是老生常谈了,但是还是希望本文的内容对大家能有一些帮助。

  • 相关阅读:
    Git原理与命令大全
    【网络安全】加解密算法最详解
    陪你阅读《区块链:从数字货币到信用社会》序一
    Splunk初识
    红帽学习记录[RHCE] ISCSI远程块储存
    DNS 域名系统与邮件服务器
    红帽学习记录[RHCE] 防火墙与网络合作
    红帽学习笔记[RHCE]网络配置与路由转发
    红帽学习笔记[RHCE]OpenLDAP 服务端与客户端配置
    红帽学习笔记[RHCSA] 第二周
  • 原文地址:https://www.cnblogs.com/tudou1223/p/9167892.html
Copyright © 2011-2022 走看看