让浏览器非阻塞加载javascript的几种方式

开发 前端
在日常当中,我们会经常遇到一些浏览器阻碍加载的情况,本文介绍了几种让浏览器非阻塞加载javascript的几种方式,希望对你有帮助,一起来看。

本文主要介绍让浏览器非阻塞加载javascript的几种方式。

通常大多数浏览器是并行下载资源的,但由于外部脚本的特殊性例如通过脚本改变文档的DOM结构、脚本之间的存在依赖关系、使用document.write 向页面输出HTML等。浏览器为了确保正确执行脚本和呈现布局在浏览器加载和执行完成它之前会完全阻塞页面后续内容的呈现和其他资源的加载。

在页面的加载过程中如果可以做到内容的逐步呈现,对于良好的用户体验来说是非常重要的。通常我们也会在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标记的字符串。不足之处和方法五一样兼容性欠缺。

总结

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

【编辑推荐】

  1. Javascript解决浏览器兼容性问题
  2. 4月超棒的JavaScript游戏开发框架推荐
  3. 13个经典JavaScript游戏 附源代码下载
  4. 高性能WEB开发之如何加载JavaScript
  5. 从零开始学习jQuery之你必须知道的JavaScript

 

责任编辑:于铁 来源: 博客园
相关推荐

2021-02-27 16:08:17

Java异步非阻塞

2021-01-07 07:52:04

浏览器网页资源加载

2017-01-05 09:07:25

JavaScript浏览器驱动

2015-06-11 14:05:46

QQ浏览器

2016-10-09 08:38:01

JavaScript浏览器事件

2009-04-25 09:30:55

Firefox浏览器

2020-03-12 11:29:51

JavaScript浏览器语言

2013-11-20 10:47:57

浏览器渲染html

2020-03-10 09:42:04

JavaScript前端线程

2010-09-15 09:12:03

JavaScript浏览器兼容

2011-07-15 09:56:54

NPAPI开发火狐

2022-02-14 22:04:50

浏览器Observer监听

2017-12-05 10:44:50

浏览器页面加载

2010-04-05 21:57:14

Netscape浏览器

2012-10-29 09:40:43

HTML5JavaScriptWebGL

2021-06-04 18:14:15

阻塞非阻塞tcp

2020-10-30 10:15:21

Chrome V8JavaScript前端

2014-10-09 09:48:14

JavaScript

2012-03-20 11:07:08

2012-03-19 17:25:22

点赞
收藏

51CTO技术栈公众号