本篇文章给大家带来的内容是关于Javascript中的defer属性和async属性的用法详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
为什么需要异步加载js文件:
不使用异步,文档在加载js代码时会阻塞其他资源的下载,导致空白页面。
(1)置于顶部的js脚本,浏览器在执行时需要花费时间去下载外链文件的代码并执行,此时会导致明显的延迟,显示为空白页面,用户无法浏览内容,也无法与页面进行交互。
(2)虽然IE8、Firefox3.5、Safari4、Chrome2都允许并行下载Javascript文件,脚本的下载过程不会互相影响,但页面的加载仍旧需要等到所有的Javascript代码下载并执行完成才能继续。正因为如此,推荐将3f1c4e4b6b16bbbd69b2ee476dc4f83a标签置于6c04bd5ca3fcae76e30b72ad730ca86d的底部。
(3)由于每个3f1c4e4b6b16bbbd69b2ee476dc4f83a标签下载时都会阻塞页面渲染,因此推荐减少3f1c4e4b6b16bbbd69b2ee476dc4f83a标签的使用。不仅对于外链脚本,内嵌脚本也是如此。浏览器在解析HTML页面时每遇到一个3f1c4e4b6b16bbbd69b2ee476dc4f83a标签都会因执行脚本而导致一定的延时。此外,考虑到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属性的3f1c4e4b6b16bbbd69b2ee476dc4f83a标签可以放在页面的任何位置,对应的Javascript文件会在页面解析到3f1c4e4b6b16bbbd69b2ee476dc4f83a标签时开始下载,但不会执行,DOM加载完成后执行(在onload事件之前调用)。
async:
(1)只用于外部脚本。
(2)async加载完成后立即执行。
附:defer属性的浏览器支持情况详见:https://caniuse.com/#feat=script-defer,搜索defer即可。
为什么需要异步加载js文件:
不使用异步,文档在加载js代码时会阻塞其他资源的下载,导致空白页面。
(1)置于顶部的js脚本,浏览器在执行时需要花费时间去下载外链文件的代码并执行,此时会导致明显的延迟,显示为空白页面,用户无法浏览内容,也无法与页面进行交互。
(2)虽然IE8、Firefox3.5、Safari4、Chrome2都允许并行下载Javascript文件,脚本的下载过程不会互相影响,但页面的加载仍旧需要等到所有的Javascript代码下载并执行完成才能继续。正因为如此,推荐将3f1c4e4b6b16bbbd69b2ee476dc4f83a标签置于6c04bd5ca3fcae76e30b72ad730ca86d的底部。
(3)由于每个3f1c4e4b6b16bbbd69b2ee476dc4f83a标签下载时都会阻塞页面渲染,因此推荐减少3f1c4e4b6b16bbbd69b2ee476dc4f83a标签的使用。不仅对于外链脚本,内嵌脚本也是如此。浏览器在解析HTML页面时每遇到一个3f1c4e4b6b16bbbd69b2ee476dc4f83a标签都会因执行脚本而导致一定的延时。此外,考虑到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属性的3f1c4e4b6b16bbbd69b2ee476dc4f83a标签可以放在页面的任何位置,对应的Javascript文件会在页面解析到3f1c4e4b6b16bbbd69b2ee476dc4f83a标签时开始下载,但不会执行,DOM加载完成后执行(在onload事件之前调用)。
async:
(1)只用于外部脚本。
(2)async加载完成后立即执行。
附:defer属性的浏览器支持情况详见:https://caniuse.com/#feat=script-defer,搜索defer即可。
以上就是对Javascript中的defer属性和async属性的用法详解的全部介绍,如果您想了解更多有关JavaScript视频教程,请关注PHP中文网。
以上是Javascript中的defer属性和async属性的用法详解的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript是现代网站的核心,因为它增强了网页的交互性和动态性。1)它允许在不刷新页面的情况下改变内容,2)通过DOMAPI操作网页,3)支持复杂的交互效果如动画和拖放,4)优化性能和最佳实践提高用户体验。

C 和JavaScript通过WebAssembly实现互操作性。1)C 代码编译成WebAssembly模块,引入到JavaScript环境中,增强计算能力。2)在游戏开发中,C 处理物理引擎和图形渲染,JavaScript负责游戏逻辑和用户界面。

JavaScript在网站、移动应用、桌面应用和服务器端编程中均有广泛应用。1)在网站开发中,JavaScript与HTML、CSS一起操作DOM,实现动态效果,并支持如jQuery、React等框架。2)通过ReactNative和Ionic,JavaScript用于开发跨平台移动应用。3)Electron框架使JavaScript能构建桌面应用。4)Node.js让JavaScript在服务器端运行,支持高并发请求。

Python更适合数据科学和自动化,JavaScript更适合前端和全栈开发。1.Python在数据科学和机器学习中表现出色,使用NumPy、Pandas等库进行数据处理和建模。2.Python在自动化和脚本编写方面简洁高效。3.JavaScript在前端开发中不可或缺,用于构建动态网页和单页面应用。4.JavaScript通过Node.js在后端开发中发挥作用,支持全栈开发。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。 1)C 用于解析JavaScript源码并生成抽象语法树。 2)C 负责生成和执行字节码。 3)C 实现JIT编译器,在运行时优化和编译热点代码,显着提高JavaScript的执行效率。

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。

JavaScript在Web开发中的主要用途包括客户端交互、表单验证和异步通信。1)通过DOM操作实现动态内容更新和用户交互;2)在用户提交数据前进行客户端验证,提高用户体验;3)通过AJAX技术实现与服务器的无刷新通信。

理解JavaScript引擎内部工作原理对开发者重要,因为它能帮助编写更高效的代码并理解性能瓶颈和优化策略。1)引擎的工作流程包括解析、编译和执行三个阶段;2)执行过程中,引擎会进行动态优化,如内联缓存和隐藏类;3)最佳实践包括避免全局变量、优化循环、使用const和let,以及避免过度使用闭包。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

Atom编辑器mac版下载
最流行的的开源编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

SublimeText3汉化版
中文版,非常好用

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。