首页
学习
活动
专区
圈层
工具
发布

script 中 defer 和 async 区别

0 1 原 理 首先,看看 script 引用的三种情况 情况1: script src="script.js">script> 没有 defer 或 async,浏览器会立即加载并执行指定的脚本...情况2: script async src="script.js">script> 有 async,加载和渲染后续文档元素的过程将和 script.js 的加载与执行并行进行(异步)。...情况3: script defer src="myscript.js">script> 有 defer,加载后续文档元素的过程将和 script.js 的加载并行进行(异步),但是 script.js...0 2 图解 说明: 绿色:html 解析 灰色:html 解析暂停 蓝色: script 下载 红色: script 执行 情况1: script> 情况2: script async>...情况3: script defer> 0 3 总结 总结 : script 是同步加载执行; async 与 defer 都是异步加载; async 文件加载完就执行,而defer 是在html解析之后

60410

Script标签的async和defer

之前有写过HTML页面渲染过程,知道了JavaScript是会阻塞DOM解析的,所以我们会把script标签放到底部防止阻塞HTML解析。...其实script还有两个属性,async和defer,也是可以使得JavaScript和DOM和css同步加载。 说着两个属性之前先简单说一下DOMContentLoaded和load。...知道了这两个事件之后,我们来说说async和defer。这两个都是用来控制外部脚本文件的,就是使用script引入,有src属性,在script标签没有src属性的内联脚本是无效的。...Defer:开启新的线程下载脚本,使HTML解析完成后执行。如果多个脚本同时生命defer,会按顺序下载和执行,同时会在DOMContentLoaded和load之前执行。...(网上有说defer也不一定按顺序,这个不知道什么情况下不按顺序) Async:H5新增属性,也是用于异步加载脚本,下载完毕立即执行。

88730
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    浅谈script标签中的async和defer

    浅谈script标签中的async和defer script标签用于加载脚本与执行脚本,在前端开发中可以说是非常重要的标签了。...defer 如果script标签设置了该属性,则浏览器会异步的下载该文件并且不会影响到后续DOM的渲染; 如果有多个设置了defer的script标签存在,则会按照顺序执行所有的script; defer...为了更直观,我们给script1.js添加了1s的延迟,给script2.js添加了2s的延迟。 ? 下图是页面加载的过程&script脚本的输出顺序。...不难看出,虽然script1加载用时虽然比script2短,但因为defer的限制,所以Ta只能等前边的脚本执行完毕后才能执行。 ? ?...例: 评论框 代码语法高亮 polyfill.js async 如果你的脚本并不关心页面中的DOM元素(文档是否解析完毕),并且也不会产生其他脚本需要的数据。

    1.3K20

    浅谈script标签中的async和defer

    浅谈script标签中的async和defer script标签用于加载脚本与执行脚本,在前端开发中可以说是非常重要的标签了。...defer 如果script标签设置了该属性,则浏览器会异步的下载该文件并且不会影响到后续DOM的渲染; 如果有多个设置了defer的script标签存在,则会按照顺序执行所有的script; defer...为了更直观,我们给script1.js添加了1s的延迟,给script2.js添加了2s的延迟。 ? 下图是页面加载的过程&script脚本的输出顺序。...不难看出,虽然script1加载用时虽然比script2短,但因为defer的限制,所以Ta只能等前边的脚本执行完毕后才能执行。 ? ?...例: 评论框 代码语法高亮 polyfill.js async 如果你的脚本并不关心页面中的DOM元素(文档是否渲染完毕),并且也不会产生其他脚本需要的数据。

    2.6K60

    Async、defer以及普通加载script区别详解

    ,下载完成后中断HTML解析并执行script,执行完成后再继续HTML解析(script的执行顺序不一定按照script标签的出现顺序,而是取决于script下载完成的顺序) script defer...='./3.js'>script> defer的方式加载1.js、2.js、3.js,观察控制台的打印结果: 普通: 结论:script出现会中断HTML加载,且script会顺序的加载、执行,所有script执行完成后再解析HTML...Defer: 结论:HTML解析和script下载同步进行;script会在HTML解析完成后和document loaded之前执行,且执行顺序和tag出现顺序一致。...而defer相对于async更具优势,不会阻塞HTML解析且script的执行顺序可以预测,有一些需要预先下载执行的script可以使用defer的方式在中引用。

    76820

    浅析script 标签的 async 和 defer 属性

    前端当然要从 HTML 开始,今天来聊聊在 script 标签中加上 async/defer 时的功能及差异。...从HTML4 开始,script> 多了 defer 属性,而 HTML5 则多了 async,两者都是用来帮助开发者控制 script> 内资源的载入及执行顺序,以及避免 DOM 的解析被资源下载卡住的...但要提醒各位,虽然 W3C 规范上说 defer 属性会是一个布尔值,但 IE9 以前的版本是自定义的,即使写成 script defer="false"> 仍然会有 defer 的效果,使用时要特别注意...例如: const script = document.createElement('script') script.src = "/something/awesome.js" document.body.append...defer 由于后台载入、不打断渲染及确保执行顺序的特点,基本上在没特殊需求的情况下,在 script> 中设置一下就行了;当然 script> 本身的摆放顺序还是要稍微留心一下。

    1.4K20

    script 的三种加载方式 (async, defer)

    Note JS 的加载分为两个部分:下载和执行。 浏览器在执行 HTML 的时候如果遇到script>时会停止页面的渲染,去下载和执行 js 的文件直接遇见会继续渲染页面。...故浏览器在执行 js 文件的时候浏览器表现为一片空白,为了解决这个问题 ECMAScript 定义了 defer 和 async 两个属性用于控制 JS 的下载和执行。...一般建议把script>标签放在结尾处,这样尽可能减少页面阻塞。 而如果想要异步执行 script,则可以给其加上 async 或 defer 属性。...1 script> defer defer 属性在 HTML 解析期间异步下载文件,并且只在 HTML 解析完成后才执行它。对于 defer,我们可以理解是将外链的 js 放在了页面底部。...js 的加载不会阻塞页面的渲染和资源的加载。不过 defer 会按照原本的 js 的顺序执行,所以如果前后有依赖关系的 js 可以放心使用。

    2.8K10

    重学js之script标签属性deferasync

    -- 普通 script:阻塞解析 -->  script src="normal.js">script>  defer:异步下载,DOM 完成后按顺序执行 -->  script defer src="defer1.js">script>  script defer src="defer2.js...-- async:异步下载,下载完成立即执行 -->  script async src="async1.js">script>  script async src="async2.js">(非 async/defer) 解析到 script> → 浏览器暂停 DOM 解析 下载脚本(阻塞解析,但浏览器会尽量并行下载 其他非阻塞资源,比如 CSS、图片、async/defer JS)...> CSS > 图片) 资源优先级策略 浏览器会优先下载阻塞渲染的 CSS 和普通 script async/defer JS、图片等优先级低一些,所以可能“延迟”下载 因此我们说“尽量并行”,实际是并行下载

    19110

    defer

    以下是对 defer 的详细介绍: 1.defer 的语法:•defer 后面跟随一个函数调用,该函数会在包含 defer 语句的函数执行完毕后被调用。...•defer 中的参数会在 defer 语句执行时被求值,因此如果你有多个 defer 语句使用相同的参数,它们会被依次求值。•在某些情况下,要特别小心 defer 中的闭包,以避免出现意外的行为。...defer执行时机 defer 语句中的函数调用会在包含 defer 语句的函数返回之前执行。...以下是关于 defer 执行时机的详细解释: 1.正常返回时的 defer 执行:•在函数执行过程中,当遇到 defer 语句时,不会立即执行 defer 中的函数调用,而是将它们压入一个栈中,以便在函数返回时执行...2.第一个 defer 语句中的匿名函数只是打印 "defer1",不对 i 进行任何修改。3.第二个 defer 语句中的匿名函数增加了 i 的值,然后打印 "defer2"。

    32220

    深入理解defer(上)defer基础

    深入理解 defer 分上下两篇文章,本文为上篇,主要介绍如下内容: 为什么需要 defer; defer 语法及语义; defer 使用要点; defer 语句中的函数到底是在 return 语句之后被调用还是...defer 语法及语义 defer语法很简单,直接在普通写法的函数调用之前加 defer 关键字即可: defer xxx(arg0, arg1, arg2, ......) defer 表示对紧跟其后的...比如前文代码中注释 1 处的 defer r.release() 表示等 f() 函数返回时再调用 r.release() 。下文我们称 defer 语句中的函数叫 defer函数。...也就是说 defer 函数会被延迟调用,但传递给 defer 函数的参数会在 defer 语句处就被准备好。...return } 这段程序的输出如下: begin ---- end defer03 defer02 defer01 可以看出f函数返回时,第一个 defer 函数最后被执行,而最后一个 defer 函数却第一个被执行

    66420

    深入理解defer(下)defer实现机制

    上一篇文章我们主要从使用的角度介绍了 defer 的基础知识,本文我们来分析一下 defer 的实现机制。 还是从一个例子程序开始。..._defer = nil sum函数的参数a sum函数的参数b 注意,defered 函数的参数并未在 _defer 结构体中定义,它所需要的参数在内存中紧跟在 _defer 结构体对象的后面。..._defer gp....到此 defer 语句中被延迟执行的函数已经挂入当前 goroutine 的 _defer 链表,我们来简单的总结一下这个过程: 编译器会把 go 代码中 defer 语句翻译成对 deferproc..._defer指向下一个_defer结构体对象 //因为需要调用的函数d.fn已经保存在了fn变量中,它的参数也已经拷贝到了栈上,所以释放_defer结构体对象 freedefer(d)

    95220
    领券