javascript延迟加载及异步(defer和async)

一直以来写代码的时候的常用习惯就是吧所有的js文件直接加载在文档的head标签里面,在写js文件的时候有时候获取一些文件对象的时候为空对象,这是由于文档结构还没有加载完,但是js文件已经加载完。也就是说虽然写了js语句来获取对象,但是由于dom结构还没有加载完成,因此获取到的是空对象,进一步测试发现在firebug的控制台下把赋值语句执行之后可以获得对象,同理是因为在文档已经得到显示之后文档结构已经处于加载完成的状态,所以可以直接获取到对应的文档对象。

解决方法用两种:defer和async。

  • defer="defer":该属性用来通知浏览器,这段脚本代码将不会产生任何文档内容。例如 JavaScript代码中的document.write()方法将不会骑作用,浏览器遇到这样的代码将会忽略,并继续执行后面的代码。属性只能是 defer,与属性名相同。在HTML语法格式下,也允许不定义属性值,仅仅使用属性名。
  • async="true/false":该属性为html5中新增的属性,它的作用是能够异步地下载和执行脚本,不因为加载脚本而阻塞页面的加载。一旦下载完毕就会立刻执行。

script中的defer属性默认情况下是false的,因此在使用时需要显式调用这一属性。
defer既可用于载入js文件,也可用于行内脚本。
加上 defer 等于在页面完全在入后再执行,相当于 window.onload ,但应用上比 window.onload 更灵活!实际上 defer 更接近于 DomContentLoad。
事实上脚本执行于onload事件之前,即文档载入后即执行,不用等于包括图片在内的资源下载完毕。

async和defer一样,都不会阻塞其他资源下载,所以不会影响页面的加载,但在async的情况下,js文档一旦下载完毕就会立刻执行,所以很有可能不是按照原本的顺序来执行,如果js有依赖性,就要注意了。

defer和async的比较

相同点:

  • 加载文件时不阻塞页面渲染;
  • 对于inline的script无效;
  • 使用这两个属性的脚本中不能调用document.write方法;
  • 有脚本的onload的事件回调;
  • 允许不定义属性值,仅仅使用属性名;

不同点:

  • html的版本html4.0中定义了defer;html5.0中定义了async;这将造成由于浏览器版本的不同而对其支持的程度不同;
  • 执行时刻:每一个async属性的脚本都在它下载结束之后立刻执行,同时会在window的load事件之前执行。所以就有可能出现脚本执行顺序被打乱 的情况;每一个defer属性的脚本都是在页面解析完毕之后,按照原本的顺序执行,同时会在document的DOMContentLoaded之前执 行。

这两个属性会有三种可能的组合:

  • 如果async为true,那么脚本在下载完成后异步执行。
  • 如果async为false,defer为true,那么脚本会在页面解析完毕之后执行。
  • 如果async和defer都为false,那么脚本会在页面解析中,停止页面解析,立刻下载并且执行。

例子:

<script type="text/javascript" src="js/index.js" defer></script>直接放在head标签中

html的body中代码:
<div id="first_menu">    <ul>        <li class="individual_info">            <div class="menu_content">                <i class="fa fa-user"></i>                <p>个人信息</p>            </div>        </li>        <li class="prizes_amount">            <div class="menu_content">                <i class="fa fa-pencil-square-o"></i>                <p>获奖统计</p>            </div>        </li>        <li class="attendence_management">            <div class="menu_content">                <i class="fa fa-calendar"></i>                <p>考勤管理</p>            </div>        </li>        <li class="expand_tables">            <div class="menu_content">                <i class="fa fa-file-excel-o"></i>                <p>拓展表项</p>            </div>        </li>    </ul></div>js代码:var li_list=$("#first_menu ul li");

没有添加defer之前获取的li_list为空对象,添加defer属性之后可以正常获取对象将async属性设置为true之后同样也可以获取到对象

参考资料:http://www.oseye.net/user/kevin/blog/53
				
时间: 2024-10-11 03:19:07

javascript延迟加载及异步(defer和async)的相关文章

Javascript的defer和async

写在前面 作为前端小白,在开发过程中,h5页面中加载js脚本,一般我们直接<script src="./index.js"></script>就加载完成了:最近在啃<JS高级>(P11)的时候,读到<script>标签的时候,发现它有俩个属性:defer和async:今天就来总结一下. 一.不写这俩个属性 这里我就先说说我对页面加载的理解: html页面加载时,至上而下加载,当遇到外联的CSS和JS的时候,会停止对DOM的加载,转而加载外

JavaScript 的 defer 与 async

当解析器遇到 script 标签时,文档的解析将停止,并立即下载并执行脚本,脚本执行完毕后将继续解析文档.但是我们可以将脚本标记为 defer,这样就不会停止文档解析,等到文档解析完成才执行脚本,也可以将脚本标记为 async,以便由其他线程对脚本进行解析和执行. 三者之间的区别? script 当解析器遇到 script 标签时,文档的解析将停止,并立即下载并执行脚本,脚本执行完毕后将继续解析文档. defer script 当解析器遇到 script 标签时,文档的解析不会停止,其他线程将下

defer=“defer”和async=“async”

<script type="text/javascript" src="demo_defer.js" defer="defer"></script> 立即下载,但延迟执行.即脚本将在页面完成解析时执行. 注:defer 属性仅适用于外部脚本,也就是在使用 src 属性时. <script type="text/javascript" src="demo_defer.js" as

defer和async的详细区别

看过javascript高级程序设计的人,在javascript高级程序设计里,应该看到了介绍了有关defer和async的区别,可是比较浅显,而且也说得不是很清楚.下面我们来通过图片来详细了解下dfer和async的区别. 下面来看看这三句话: 1.<script src="script.js"></script> 没有 defer 或 async,浏览器会立即加载并执行指定的脚本,"立即"指的是在渲染该 script 标签之下的文档元素之

script的defer和async

我们常用的script标签,有两个和性能.js文件下载执行相关的属性:defer和async defer的含义[摘自https://developer.mozilla.org/En/HTML/Element/Script] This Boolean attribute is set to indicate to a browser that the script is meant to be executed after the document has been parsed. async的含

HTML5 defer和async的区别

在HTML页面中插入Javascript的主要方法,就是使用<script>元素.这个元素由Netscape创造并在Netscape Navigator 2中首先实现.后来,这个元素就被加入到正式的HTML规范中.HTML4.01为<script>定义了6个属性,包括defer和async.defer和async都是可选的,且只对外部脚本文件有效. 一.当浏览器解析到script脚本,没有defer或async时: <script src="main.js"

脚本引用中使用defer和async用法和区别

是的,就是在页面脚本引用的时候设置defer或者async,为什么会有这两个属相来辅助脚本加载那,因为浏览器在遇到script标签的时候,文档的解析会停止,不再构建document,有时打开一个网页上会出现空白一段时间,浏览器显示是刷新请求状态(也就是一直转圈),这就会给用户很不好的体验,defer和async的合理使用就可以避免这个情况,而且通常script的位置建议写在页面底部(移动端应用的比较多,这两个都是html5中的新属性). 1.默认引用 script:<script type=&quo

JS - defer 和 async

普通 <script src="script.js"></script> 没有 defer 或 async,浏览器会立即加载并执行指定的脚本,"立即" 指的是在渲染该 script 标签之下的文档元素之前,也就是说不等待后续载入的文档元素,读到就加载并执行. async <script async src="script.js"></script> 有 async,加载和渲染后续文档元素的过程将和

js中sync、defer、async的区别

<script src="script.js"></script> 没有 defer 或 async,浏览器会默认为同步sync,会立即加载并执行指定的脚本,"立即"指的是在渲染该 script 标签之下的文档元素之前,也就是说不等待后续载入的文档元素,读到就加载并执行. <script async src="script.js"></script> 有 async,加载和渲染后续文档元素的过程将和