Posted by on 2012/02/02. .
1. head里的顺序如下,考虑会对请求有何影响:
a. 外部js在css前面
b. 外部js在css后面
c. 内部js在css前面
d. 内部js在css后面
e. 内联css在外联css前面
f. 内联css在外联css后面
结果:
a,b – head里出现外联js,无论如何放,css文件都不能和body里的请求并行。补充:body里dom渲染取决于head里的js执行完。 (图1)c – head里的内联js只要在所有外联css前面,css文件可以和body里的请求并行(图2)d – head里的内联js只要在任一外联css后面,css文件就不能和body里的请求并行。补充:原因也是要等js执行完(图1)e – firefox/ie下,要等1.css加载完生效。safari/chrome下,则先生效,再加载1.cssf – 等1.css加载完生效2. 内联js要等它前面的所有外联css文件加载完后执行。之前写过一篇。
3. 外联js放在页面最后,高级浏览器会自动做优化。如:
firefox/chrome/safari加载的优化处理相似。见图3。
4. 内联长执行时间js,无论放在页面任何位置,都会影响整个页面的渲染。,如:
在页面初始执行阶段如果有长执行时间的内联js,对性能的影响是非常非常严重的!但是,如果把那段执行5s的js放到外部就不会有上述影响,或者移到domreay/onload后执行也可以。
依据上述结论组织页面中的css和js才会更合理。
感谢玉伯的这篇很好做了解释也指出一些问题: