JavaScript

2017-08-22  本文已影响0人  asusususu
  1. 基本语法:借鉴C语言和Java语言。
  2. 数据结构:借鉴Java语言,包括将值分成原始值和对象两大类。
  3. 函数的用法:借鉴Scheme语言和Awk语言,将函数当作第一等公民,并引入闭包。
  4. 原型继承模型:借鉴Self语言(Smalltalk的一种变种)。
  5. 正则表达式:借鉴Perl语言。
  6. 字符串和数组处理:借鉴Python语言。

CSS和JS的放置顺序

当浏览器从服务器接收到了html文档,并把html在内存中转换成DOM树,在转换过程中如果发现某个节点上引用了CSS或者image,就会再发一个request去请求CSS或image,然后继续执行下面的转换,而不需要等待request的返回,当request返回后,只需要把返回的内容放入到DOM树中对应的位置就可以了。但当引用了JS的时候,浏览器发送一个JS request就会一直等待该request的返回。

由于Render Tree是由DOM树和CSSOM树组合成的,html页面需要等到CSS解析完后才能完成渲染,所以CSS应放在head标签内,优先下载解析,以避免页面元素由于样式缺失造成瞬间的白页或者给用户闪烁感。

因为浏览器需要一个稳定的dom树结构,而且js中很有可能有代码直接改变了dom树结构,浏览器为了防止出现js修改dom树,需要重新构建dom树的情况,所以就会阻塞其他的下载和呈现。

将JavaScript放在head内和body底部的区别也在于此,放在head里面,由于浏览器发现head里面有JavaScript标签就会暂时停止其他渲染行为,等待JavaScript下载并执行完成才能接着往下渲染,而这个时候由于在head里面这个时候页面是白的;如果将JavaScript放在页面底部,render Tree已经完成大部分,所以此时页面有内容呈现,即使遇到JavaScript阻塞渲染,也不会有白屏出现

JS的执行有可能依赖最新样式。比如,可能会有var width=$('#id').width,这意味着,JS代码在执行前,浏览器必须保证在此JS之前的所有CSS(无论外链还是内嵌)都已下载和解析完成。

把JS放在CSS后会导致页面阻塞,去等待CSS的下载。
另外如果要在head引入JS尽量将JS内嵌。

带有 defer 属性的<script>标签可以放置在文档的任何位置。对应的 JavaScript 文件将在页面解析到<script>标签时开始下载,但不会执行,直到 DOM 加载完成,即onload事件触发前才会被执行。当一个带有defer属性的 JavaScript 文件下载时,它不会阻塞浏览器的其他进程,因此这类文件可以与其他资源文件一起并行下载。

白屏和FOUC

repaint reflow

repaint主要是针对某一个DOM元素进行的重绘,reflow则是回流,针对整个页面的重排。

异步加载

  1. defer 属性规定是否对脚本执行进行延迟,直到页面加载为止。
<script type="text/javascript" defer="defer"> 
alert(document.getElementById("p1").firstChild.nodeValue); 
</script> 
  1. async 属性规定一旦脚本可用,则会异步执行。
<script type="text/javascript" src="demo_async.js" async="async"></script> 
上一篇 下一篇

猜你喜欢

热点阅读