让浏览器非阻塞加载javascript的几种方法小结


Posted in Javascript onApril 25, 2011

浏览器为了确保正确执行脚本和呈现布局在浏览器加载和执行完成它之前会完全阻塞页面后续内容的呈现和其他资源的加载。

    在页面的加载过程中如果可以做到内容的逐步呈现,对于良好的用户体验来说是非常重要的。通常我们也会在wondow对象的onload事件处理函数中做一些事情,但由于脚本阻塞加载和呈现的特性这一方面增加了页面载入时间推迟了onload事件的触发,另一方面也延迟了用户所期待的反馈。这就需要我们使用一些方法来让浏览器以非阻塞的方式加载外部脚本。

一  使用XMLHttpRequest对象异步方式加载外部脚本。

    这种方式好处是触发较少的浏览器忙指示器,能够被所有现代浏览器的所支持。不足的之处在于由于浏览器的跨域安全机制所以只能允许加载同域下外部脚本。另外如果多个脚本之间存在依赖关系的话,需要使用编写相关的队列管理脚本来控制多个脚本的执行顺序。

二  使用Javascript来动态创建外部脚本的SCRIPT元素

   这种方式是我认为跨域并行加载外部脚本情况下的最佳方案,实现方法是使用Javascript来动态的创建在HTML中引用外部脚本所需要srcript元素并给创建的srcript元素的src属性设置相应的外部脚本的URL来实现和其他资源并行加载。

四  使用iframe加载外部脚本

    这种方式我们需要使用一个新HTML页面把外部脚本转换成到该HTML页面的行内脚本,然后在主页面中使用iframe加载这个包含脚本的HTML页面,使用这种方式需要重构部分代码来访问主页面中DOM元素。而且IFRAM是开销相对较大DOM元素,同样也有跨域限制。

五 使用Script标签的 derfer 属性

    这种方式是实现非阻塞并行加载外部脚本的最简单的方式,只需要在引用外部脚本的是常规方式上给SCRIPT标签应用defer属性即可。但是使用这种方式加载外部脚本缺点是它只在部门浏览器中实现并行加载因此兼容性欠缺。

六 docuument.write script tag

    这种方式实现起来也比较简单,就是直接使用是javascript的document.write方法来输出在HTML中引用外部脚本的script标记的字符串。不足之处和方法五一样兼容性欠缺。

总结

   上述几种方式需要根据具体需求,如是否需要跨域?是否需要确保脚本按顺序执行?是否需要触发更多或更少的浏览器的忙指示器?以及兼容性,支持的代码量来确定来综合考虑那种方式才是追合适的。

Javascript 相关文章推荐
javascript 写类方式之六
Jul 05 Javascript
javascript Base类 包含基本的方法
Jul 22 Javascript
javascript 模拟点击广告
Jan 02 Javascript
jquery上传插件fineuploader上传文件使用方法(jquery图片上传插件)
Dec 05 Javascript
Jquery异步提交表单代码分享
Mar 26 Javascript
详解JavaScript中的forEach()方法的使用
Jun 08 Javascript
javascript实现uploadify上传格式以及个数限制
Nov 23 Javascript
Ext JS动态加载JavaScript创建窗体的方法
Jun 23 Javascript
chrome浏览器如何断点调试异步加载的JS
Sep 05 Javascript
javascript中call,apply,bind函数用法示例
Dec 19 Javascript
JavaScript代码模拟鼠标自动点击事件示例
Aug 07 Javascript
解决Antd Table组件表头不对齐的问题
Oct 27 Javascript
jQuery 版元素拖拽原型代码
Apr 25 #Javascript
30个最好的jQuery 灯箱插件分享
Apr 25 #Javascript
分享27个jQuery 表单插件集合推荐
Apr 25 #Javascript
分享14个很酷的jQuery导航菜单插件
Apr 25 #Javascript
23个超流行的jQuery相册插件整理分享
Apr 25 #Javascript
基于jquery的二级联动菜单实现代码
Apr 25 #Javascript
jQuery判断元素是否是隐藏的代码
Apr 24 #Javascript
You might like
模仿OSO的论坛(二)
2006/10/09 PHP
php外部执行命令函数用法小结
2016/10/11 PHP
PHP注释语法规范与命名规范详解篇
2018/01/21 PHP
IE event.srcElement和FF event.target 功能比较
2010/03/01 Javascript
js控制iframe的高度/宽度让其自适应内容
2014/04/09 Javascript
js控制鼠标事件移动及移出效果显示
2014/10/19 Javascript
js代码实现无缝滚动(文字和图片)
2015/08/20 Javascript
jQuery实现div随意拖动的实例代码(通用代码)
2016/01/28 Javascript
json2.js 入门教程之使用方法与实例分析
2017/09/14 Javascript
JavaScript中常见内置函数用法示例
2018/05/14 Javascript
微信小程序实现点击效果
2019/06/21 Javascript
解决微信小程序中的滚动穿透问题
2019/09/16 Javascript
[39:02]DOTA2亚洲邀请赛 3.31 小组赛 B组 Mineski vs VGJ.T
2018/04/01 DOTA
[00:59]DOTA2荣耀之路1:Doom is back!weapon X!
2018/05/22 DOTA
python中函数默认值使用注意点详解
2016/06/01 Python
Python简单实现安全开关文件的两种方式
2016/09/19 Python
实用自动化运维Python脚本分享
2018/06/04 Python
在双python下设置python3为默认的方法
2018/10/31 Python
python实现简单成绩录入系统
2019/09/19 Python
使用python 将图片复制到系统剪贴中
2019/12/13 Python
python 瀑布线指标编写实例
2020/06/03 Python
Python中的流程控制详解
2021/02/18 Python
德国在线购买葡萄酒网站:Geile Weine
2019/09/24 全球购物
戴尔马来西亚官网:Dell Malaysia
2020/05/02 全球购物
python+selenium小米商城红米K40手机自动抢购的示例代码
2021/03/24 Python
工程现场管理求职自荐信
2013/10/02 职场文书
妈妈的账单教学反思
2014/02/06 职场文书
会计师职业生涯规划范文
2014/02/18 职场文书
乔布斯斯坦福大学演讲稿
2014/05/23 职场文书
创先争优一句话承诺
2014/05/29 职场文书
正风肃纪剖析材料
2014/09/30 职场文书
新学期开学寄语2016
2015/12/04 职场文书
2016年公司“3.12”植树节活动总结
2016/03/16 职场文书
2019年幼儿园管理条例范本!
2019/07/17 职场文书
CSS3实现的水平标题菜单
2021/04/14 HTML / CSS
Python爬虫基础之简单说一下scrapy的框架结构
2021/06/26 Python