JavaScript值延迟脚本和异步脚本

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript值延迟脚本和异步脚本相关的知识,希望对你有一定的参考价值。

html 4.0为<script>标签定义了defer属性,这个属性的用途是表名脚本在执行时,不会影响页面的构造。也就是说,脚本会延迟到整个页面解析完毕之后在运行,因此,在<script>元素中设置defer属性,相当于告诉浏览器立即下载,但延迟执行。但是有一种特殊情况,看如下代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <script src="aaa.js" defer="defer"></script>
    <script src="bbb.js" defer="defer"></script>
</head>
<body>
<div id="div"></div>
</body>
</html>

上面代码有有两个外部脚本,且它们都被设置成延迟加载,HTML5的规范要求脚本按照他们出现的先后顺序执行,因此第一个延迟脚本会先于第二个延迟脚本执行,但是,事实并非如此,延迟脚本不一定会按照顺序执行,因此最好只包含一个延迟脚本!

 

异步脚本:

与defer类似,async只适用与外部脚本,并告诉浏览器立即下载文件,标记为async的脚本并不保证按照他们指定的先后顺序执行。如下代码:

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title></title>
    <script src="aaa.js"  async></script>
    <script src="bbb.js"  async></script>
</head>
<body>
<div id="div"></div>
</body>
</html>

上面代码中的两个外部脚本文件,都被设置成异步加载的方式,但是第二个脚本问价可能会先于第一个脚本文件之前执行。因此,确保两者之间互不用来非常重要。

以上是关于JavaScript值延迟脚本和异步脚本的主要内容,如果未能解决你的问题,请参考以下文章

js的延迟脚本----defer与异步脚本----async

script元素

在 Wordpress 中延迟内联脚本

如何延迟或异步此 WordPress javascript 片段以最后加载以加快页面加载时间?

javascript脚本如何异步加载,有啥作用

javascript学习笔记