JS加载与运行
来源:互联网 发布:美即黑面膜怎么样 知乎 编辑:程序博客网 时间:2024/05/29 11:13
高性能JS编程之加载与运行
原则:
第一条定律:将脚本放在底部——因为脚本阻塞其他页面资源的下载过程,所以推荐的办法是:将所有<script>标签放在尽可能接近<body>标签底部的位置,尽量减少对整个页面下载的影响。保证页面在脚本运行之前完成解析
第二条定律:限制页面的<script>总数——由于每个<script>标签下载时阻塞页面解析过程,所以限制页面的<script>总数也可以改善性能。这个规则对内联脚本和外部脚本同样适用。通过一个打包工具实现将多个JS文件打包为一个。页面的<script>标签越少,页面的加载速度就越快,响应也更加迅速。
过程分析:
JavaScript具有阻塞特征,当JavaScript运行时其他的事情不能被浏览器处理,这意味着<script>标签的出现使整个页面因脚本解析、运行而出现等待。当浏览器遇到一个<script>标签时,无法知JavaScript是否在<p>标签中添加内容。因此,浏览器停下来,运行此JavaScript代码,然后再继续解析、翻译页面。同样的事情发生在使用src属性加载JavaScript的过程中。浏览器必须首先下载外部文件的代码,这要占用一些时间,然后解析并运行此代码。此过程中,页面解析和用户交互是被完全阻塞的。
非阻塞脚本的秘密在于,等页面完成加载之后,再加载JavaScript源码。从技术角度讲,这意味着在window的load事件发出之后开始下载代码。
1、如目标浏览器只包括Internet Explorer 和Firefox 3.5,添加defer属性可支出JS并行下载。任何带有defer属性的<script>元素在DOM加载完成之前不会被执行,不论是内联脚本还是外部脚本文件。
2、动态创建<script>元素,用它下载并执行代码
3、用XHR对象下载代码,并注入到页面中
非阻塞JavaScript加载库是LABjs(http://labjs.com/),$LAB.script()函数用于下载一个JavaScript文件,$LAB.wait()函数用于指出一个函数,该函数等待文件下载完成并运行之后才会被调用。LABjs的独特之处在于它能够管理依赖关系,LABjs通过wait()函数允许你指定哪些文件应该等待其他文件。
阅读全文
1 0
- JS加载与运行
- js与页面加载
- 加载地址与运行地址
- 异步动态加载JS 并运行
- 在页面加载后运行js
- js加载与执行顺序
- JS执行与页面加载
- html与js加载顺序
- JS动态加载JS与CSS文件
- JS动态加载JS与CSS文件
- JS动态加载JS与CSS文件
- JS动态加载JS与CSS文件
- 代码的加载地址与运行地址
- 代码的加载地址与运行地址
- javascript性能影响–加载与运行
- javascript加载与运行的时机
- JVM类加载与运行时优化
- JS与JQ图片的预加载与懒加载
- nio基本使用
- 【知了堂学习笔记】Model1、Model2和MVC架构模式
- poj 1451 难度:中等 字典树+搜索
- 线性表顺序结构增删改查
- STL库中的list的使用和模拟实现
- JS加载与运行
- JVM类加载过程,JDK和JER区别
- log4j学习笔记
- Product of Array Except Self
- [Java--面试]--阿里巴巴面试2016
- 二分查找,你真的懂吗
- 欢迎使用CSDN-markdown编辑器
- 图像识别
- python 多并发竞争微信token刷新问题的解决方案