本篇文章给大家带来的内容是关于javascript中的defer属性和async属性的用法详解,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
为什么需要异步加载js文件:
不使用异步,文档在加载js代码时会阻塞其他资源的下载,导致空白页面。
(1)置于顶部的js脚本,浏览器在执行时需要花费时间去下载外链文件的代码并执行,此时会导致明显的延迟,显示为空白页面,用户无法浏览内容,也无法与页面进行交互。
(2)虽然IE8、Firefox3.5、Safari4、Chrome2都允许并行下载Javascript文件,脚本的下载过程不会互相影响,但页面的加载仍旧需要等到所有的Javascript代码下载并执行完成才能继续。正因为如此,推荐将
(3)由于每个
立即学习“Java免费学习笔记(深入)”;
defer和async的用法:
相同点:defer和async均是用来异步加载脚本。采用并行下载,在下载过程中不会产生阻塞。
不同点:
defer:
(1)即可用于加载外部脚本,也可用于加载内嵌脚本。内嵌脚本仅限于IE9及以下,主流浏览器根据W3C的HTML5规范:defer仅当src属性声明时生效。
如:
//外部脚本//内嵌脚本
(2)带有defer属性的
async:
(1)只用于外部脚本。
(2)async加载完成后立即执行。
附:defer属性的浏览器支持情况详见:https://caniuse.com/#feat=script-defer,搜索defer即可。
DELPHI控件属性、方法、事件及常用函数 一. TmainMemu控件 该控件是一个标准的菜单控件,运用它为窗口提供菜单。该对象的层次结构为:TObject—TPersistent--TCompoment—TMenu。 属性 1-AutoMetge:Boolean 功能:用于确定非MID程序中非主Form上的菜单要不要和主Form的菜单合并。主Form菜单AutoMerge的特性总是False。此外,还要设置菜单项的GroupIndex属性。 2-BiDiMode
为什么需要异步加载js文件:
不使用异步,文档在加载js代码时会阻塞其他资源的下载,导致空白页面。
(1)置于顶部的js脚本,浏览器在执行时需要花费时间去下载外链文件的代码并执行,此时会导致明显的延迟,显示为空白页面,用户无法浏览内容,也无法与页面进行交互。
(2)虽然IE8、Firefox3.5、Safari4、Chrome2都允许并行下载Javascript文件,脚本的下载过程不会互相影响,但页面的加载仍旧需要等到所有的Javascript代码下载并执行完成才能继续。正因为如此,推荐将
defer和async的用法:
相同点:defer和async均是用来异步加载脚本。采用并行下载,在下载过程中不会产生阻塞。
不同点:
defer:
(1)即可用于加载外部脚本,也可用于加载内嵌脚本。内嵌脚本仅限于IE9及以下,主流浏览器根据W3C的HTML5规范:defer仅当src属性声明时生效。
如:
//外部脚本//内嵌脚本
(2)带有defer属性的
async:
(1)只用于外部脚本。
(2)async加载完成后立即执行。
附:defer属性的浏览器支持情况详见:https://caniuse.com/#feat=script-defer,搜索defer即可。
以上就是对Javascript中的defer属性和async属性的用法详解的全部介绍,如果您想了解更多有关JavaScript视频教程,请关注PHP中文网。










