让浏览器非阻塞加载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控制frame,iframe的src属性代码
Dec 31 Javascript
深入理解JavaScript 闭包究竟是什么
Apr 12 Javascript
ie下$.getJSON出现问题的解决方法
Feb 12 Javascript
原生javaScript实现图片延时加载的方法
Dec 22 Javascript
jQuery入门介绍之基础知识
Jan 13 Javascript
Jquery 整理元素选取、常用方法一览表
Nov 26 Javascript
js实现方块上下左右移动效果
Aug 17 Javascript
在Vuex使用dispatch和commit来调用mutations的区别详解
Sep 18 Javascript
详解Vue+Element的动态表单,动态表格(后端发送配置,前端动态生成)
Apr 20 Javascript
layer.alert回调函数执行关闭弹窗的实例
Sep 11 Javascript
小程序实现长按保存图片的方法
Dec 31 Javascript
浅谈Vue组件单元测试究竟测试什么
Feb 05 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
帅气的琦玉老师
2020/03/02 日漫
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
php empty() 检查一个变量是否为空
2011/11/10 PHP
php操作redis常见方法示例【key与value操作】
2020/04/14 PHP
一个js写的日历(代码部分网摘)
2009/09/20 Javascript
Extjs中DisplayField的日期或者数字格式化扩展
2010/09/03 Javascript
用javascript替换URL中的参数值示例代码
2014/01/27 Javascript
seajs中模块的解析规则详解和模块使用总结
2014/03/12 Javascript
javascript的创建多行字符串的7种方法
2014/04/29 Javascript
jquery实现简单的无缝滚动
2015/04/15 Javascript
jQuery原型属性和原型方法详解
2015/07/07 Javascript
js面向对象编程总结
2017/02/16 Javascript
angular2+nodejs实现图片上传功能
2017/03/27 NodeJs
使用html+js+css 实现页面轮播图效果(实例讲解)
2017/09/21 Javascript
基于vue开发微信小程序mpvue-docs跳转页面功能
2019/04/10 Javascript
vue swipe自定义组件实现轮播效果
2019/07/03 Javascript
vue中在vuex的actions中请求数据实例
2019/11/08 Javascript
jQuery+PHP+Ajax实现动态数字统计展示功能
2019/12/25 jQuery
bootstrap实现嵌套模态框的实例代码
2020/01/10 Javascript
Python正则替换字符串函数re.sub用法示例
2017/01/19 Python
Python学习笔记之集合的概念和简单使用示例
2019/08/22 Python
三维科技面试题
2013/07/27 面试题
高中生学习的自我评价
2013/12/14 职场文书
高中毕业生自我鉴定例文
2013/12/29 职场文书
西式婚礼证婚词
2014/01/12 职场文书
《争吵》教学反思
2014/02/15 职场文书
《小白兔和小灰兔》教学反思
2014/02/18 职场文书
群众路线教育实践活动心得体会
2014/03/07 职场文书
买卖协议书范本
2014/04/21 职场文书
三分钟演讲稿范文
2014/04/24 职场文书
省文明单位申报材料
2014/05/08 职场文书
质量标语大全
2014/06/12 职场文书
机票销售员态度不好检讨书
2014/09/27 职场文书
合法的离婚协议书范本
2014/10/23 职场文书
信访维稳工作汇报
2014/10/27 职场文书
Python中常见的导入方式总结
2021/05/06 Python