首页 > web前端 > js教程 > 正文

Javascript中的defer属性和async属性的用法详解

云罗郡主
发布: 2018-10-17 15:10:12
转载
2165人浏览过

本篇文章给大家带来的内容是关于javascript中的defer属性和async属性的用法详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

为什么需要异步加载js文件:

不使用异步,文档在加载js代码时会阻塞其他资源的下载,导致空白页面。

(1)置于顶部的js脚本,浏览器在执行时需要花费时间去下载外链文件的代码并执行,此时会导致明显的延迟,显示为空白页面,用户无法浏览内容,也无法与页面进行交互。 

(2)虽然IE8、Firefox3.5、Safari4、Chrome2都允许并行下载Javascript文件,脚本的下载过程不会互相影响,但页面的加载仍旧需要等到所有的Javascript代码下载并执行完成才能继续。正因为如此,推荐将<script>标签置于<body>的底部。  

  (3)由于每个<script>标签下载时都会阻塞页面渲染,因此推荐减少<script>标签的使用。不仅对于外链脚本,内嵌脚本也是如此。浏览器在解析HTML页面时每遇到一个<script>标签都会因执行脚本而导致一定的延时。此外,考虑到HTTP请求带来额外的性能开销,下载单个100KB的文件将比下载4个25KB的文件更快。

立即学习Java免费学习笔记(深入)”;

defer和async的用法:

相同点:defer和async均是用来异步加载脚本。采用并行下载,在下载过程中不会产生阻塞。

不同点:

defer:

(1)即可用于加载外部脚本,也可用于加载内嵌脚本。内嵌脚本仅限于IE9及以下,主流浏览器根据W3C的HTML5规范:defer仅当src属性声明时生效。

如:

//外部脚本<script src="1.js" defer></script>//内嵌脚本<script defer>
    console.log("defer");</script>
登录后复制

(2)带有defer属性的<script>标签可以放在页面的任何位置,对应的Javascript文件会在页面解析到<script>标签时开始下载,但不会执行,DOM加载完成后执行(在onload事件之前调用)。

async: 

(1)只用于外部脚本。

(2)async加载完成后立即执行。

附:defer属性的浏览器支持情况详见:https://caniuse.com/#feat=script-defer,搜索defer即可。

SpeakingPass-打造你的专属雅思口语语料
SpeakingPass-打造你的专属雅思口语语料

使用chatGPT帮你快速备考雅思口语,提升分数

SpeakingPass-打造你的专属雅思口语语料 25
查看详情 SpeakingPass-打造你的专属雅思口语语料

为什么需要异步加载js文件:

不使用异步,文档在加载js代码时会阻塞其他资源的下载,导致空白页面。

(1)置于顶部的js脚本,浏览器在执行时需要花费时间去下载外链文件的代码并执行,此时会导致明显的延迟,显示为空白页面,用户无法浏览内容,也无法与页面进行交互。
(2)虽然IE8、Firefox3.5、Safari4、Chrome2都允许并行下载Javascript文件,脚本的下载过程不会互相影响,但页面的加载仍旧需要等到所有的Javascript代码下载并执行完成才能继续。正因为如此,推荐将<script>标签置于<body>的底部。
(3)由于每个<script>标签下载时都会阻塞页面渲染,因此推荐减少<script>标签的使用。不仅对于外链脚本,内嵌脚本也是如此。浏览器在解析HTML页面时每遇到一个<script>标签都会因执行脚本而导致一定的延时。此外,考虑到HTTP请求带来额外的性能开销,下载单个100KB的文件将比下载4个25KB的文件更快。

defer和async的用法:

相同点:defer和async均是用来异步加载脚本。采用并行下载,在下载过程中不会产生阻塞。

不同点:

defer:

(1)即可用于加载外部脚本,也可用于加载内嵌脚本。内嵌脚本仅限于IE9及以下,主流浏览器根据W3C的HTML5规范:defer仅当src属性声明时生效。

如:

//外部脚本<script src="1.js" defer></script>//内嵌脚本<script defer>
    console.log("defer");</script>
登录后复制

(2)带有defer属性的<script>标签可以放在页面的任何位置,对应的Javascript文件会在页面解析到<script>标签时开始下载,但不会执行,DOM加载完成后执行(在onload事件之前调用)。

async:

(1)只用于外部脚本。

(2)async加载完成后立即执行。

附:defer属性的浏览器支持情况详见:https://caniuse.com/#feat=script-defer,搜索defer即可。

以上就是对Javascript中的defer属性和async属性的用法详解的全部介绍,如果您想了解更多有关JavaScript视频教程,请关注PHP中文网。

以上就是Javascript中的defer属性和async属性的用法详解的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:csdn网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号