延迟脚本和异步脚本

延迟脚本

一般情况下,想要把脚本延迟到整个页面都加载完毕后再运行,把<script>标签放在</body>上面便可。

但也可以这样子:

<script type="text/javascript" defer="defer" src="example1.js"></script>

这样也可将达到同样的目的,并保持代码的整洁性。

异步脚本

与defer类似,async都只用于外部脚本文件,并告诉浏览器立即下载文件。

但与defer不同的是,async的脚本并不保证按照指定他们的先后顺序执行。

使用async也和defer有点不同:

<script type="text/javascript" async src="example1.js"></script>


注意:在xhtml文档中,必须这个样子:

<script type="text/javascript" async="async" src="example1.js"></script>


然后看看下面一段代码:

<!DOCTYPE html>
<html>
    <head>
        <script type="text/javascript" async src="example1.js"></script>
        <script type="text/javascript" async src="example2.js"></script>
    </head>
    <body>
        <!--内容-->
    </body>
</html>

在以上这段代码中,example2.js可能在example1.js之前执行。因此,确保两者间互不依赖相当重要。

指定async属性的目的是不让页面等待两个脚本下载和执行,从而异步加载其他内容。所以,异步脚本不可再加载期间修改DOM。

转载于:https://my.oschina.net/evanyan/blog/301528

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值