Heim >Web-Frontend >js-Tutorial >高性能web开发 如何加载JS,JS应该放在什么位置?_javascript技巧

高性能web开发 如何加载JS,JS应该放在什么位置?_javascript技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-05-16 18:27:191187Durchsuche

外部JS的阻塞下载
所有浏览器在下载JS的时候,会阻止一切其他活动,比如其他资源的下载,内容的呈现等等。至到JS下载、解析、执行完毕后才开始继续并行下载其他资源并呈现内容。

有人会问:为什么JS不能像CSS、image一样并行下载了?这里需要简单介绍一下浏览器构造页面的原理,
当浏览器从服务器接收到了HTML文档,并把HTML在内存中转换成DOM树,在转换的过程中如果发现某个节点(node)上引用了CSS或者IMAGE,就会再发1个request去请求CSS或image,然后继续执行下面的转换,而不需要等待request的返回,当request返回后,只需要把返回的内容放入到DOM树中对应的位置就OK。但当引用了JS的时候,浏览器发送1个js request就会一直等待该request的返回。因为浏览器需要1个稳定的DOM树结构,而JS中很有可能有代码直接改变了DOM树结构,比如使用document.write 或 appendChild,甚至是直接使用的location.href进行跳转,浏览器为了防止出现JS修改DOM树,需要重新构建DOM树的情况,所以就会阻塞其他的下载和呈现.

阻塞下载图:下图是访问blogjava首页的时间瀑布图,可以看出来开始的2个image都是并行下载的,而后面的2个JS都是阻塞下载的(1个1个下载)。
高性能web开发 如何加载JS,JS应该放在什么位置?_javascript技巧
嵌入JS的阻塞下载
嵌入JS是指直接写在HTML文档中的JS代码。上面说了引用外部的JS会阻塞其后的资源下载和其后的内容呈现,哪嵌入的JS又会是怎样阻塞的了,看下面的列2个代码:
代码1:

复制代码 代码如下:


    blogjava>
  • CSDN>

  • 博客园>

  • ABC>

  • AAA>






      • MSN>

      • GOOGLE>

      • YAHOO>




      代码2(test.zip里面的代码与代码1的JS代码一模一样):
      复制代码 代码如下:



      • blogjava>

      • CSDN>

      • 博客园>

      • ABC>

      • AAA>






        • 高性能web开发 如何加载JS,JS应该放在什么位置?_javascript技巧br />
          高性能web开发 如何加载JS,JS应该放在什么位置?_javascript技巧

          时间瀑布图:
          高性能web开发 如何加载JS,JS应该放在什么位置?_javascript技巧
          从时间瀑布图中可以看出,代码2中,CSS和图片并没有并行下载,而是等待CSS下载完毕后才去并行下载后面的2个图片,当CSS后面跟着嵌入的JS的时候,该CSS就会出现阻塞后面资源下载的情况。
          有人可能会问,这里为什么不说说嵌入的JS阻塞了后面的资源,而是说CSS阻塞了? 想想我们现在用的是1个空函数,解析这个空函数1ms就够,而后面2个图片是等CSS下载完1.3s后才开始下载。大家还可以试试把嵌入JS放到CSS前面,就不会出现阻塞的情况了。
          根本原因:因为浏览器会维持html中css和js的顺序,样式表必须在嵌入的JS执行前先加载、解析完。而嵌入的JS会阻塞后面的资源加载,所以就会出现上面CSS阻塞下载的情况。
          嵌入JS应该放在什么位置

          1、放在底部,虽然放在底部照样会阻塞所有呈现,但不会阻塞资源下载。
          2、如果嵌入JS放在head中,请把嵌入JS放在CSS头部。
          3、使用defer
          4、不要在嵌入的JS中调用运行时间较长的函数,如果一定要用,可以用setTimeout来调用

          PS:很多网站喜欢在head中嵌入JS,并且习惯放在CSS后面,比如看到的www.qq.com,当然也有很多网站是把JS放到CSS前面的,比如yahoo,google

          [声明] 转载请注明出处:http://www.blogjava.net/BearRui/。 禁止商用!
      Stellungnahme:
      Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn