当前位置: 首页 > news >正文

script 标签中 defer 和 async 属性的区别

script 标签中的 defer Vs. async

在 HTML 中,script 标签可以使用 deferasync 属性来控制外部 JavaScript 脚本加载和执行的方式deferasync 都可以提高页面的加载性能,主要区别整理如下。

区别点deferasync
加载顺序按顺序加载异步加载,不保证加载顺序
执行顺序按文档中出现的顺序执行加载完立即执行,不保证执行顺序
执行时机HTML 文档完全解析后执行
但在 DOMContentLoaded 事件之前
可能在 HTML 文档解析完成之前执行
阻塞行为不会阻塞 HTML 的解析,浏览器解析 HTML 文档,脚本在后台异步加载不会阻塞 HTML 的解析,浏览器解析 HTML 文档,脚本在后台异步加载
适用场景需要保证执行顺序,并在文档解析完成后再执行的脚本。如依赖于 DOM 的脚本。不依赖其他脚本不依赖 DOM 的独立脚本。如分析工具或广告脚本。

注意:如果不使用 deferasync 属性,浏览器在遇到 <script> 标签时会阻塞 HTML 解析,直到脚本加载和执行完毕后才继续解析。使用 deferasync 后,脚本的记载是异步的,由网络进程实现,不会阻塞HTML 解析;脚本的执行是同步的,会占用渲染进程,defer 脚本的执行不会阻塞解析,但 async 脚本可能会阻塞 HTML 解析。

http://www.lryc.cn/news/357923.html

相关文章:

  • 【axios】的浅度分析
  • 基于单片机的步进电机控制系统研究
  • Fine-tuning和模型训练的关系
  • 【ai】livekit:Agents 3 : pythonsdk和livekit-agent的可编辑模式下的安装
  • 【传知代码】BERT论文解读及情感分类实战-论文复现
  • 【C language】判断一个正整数是否是2^n
  • 解锁Android高效数据传输的秘钥 - Parcelable剖析
  • 前端 CSS 经典:filter 滤镜
  • 专业的力量-在成为专家的道路上前进
  • 10分钟掌握FL Studio21中文版,音乐制作更高效!
  • Python中4种读取JSON文件和提取JSON文件内容的方法
  • el-pagination在删除非第一页的最后一条数据遇到的问题
  • 视频汇聚平台LntonCVS视频监控系统前端错误日志记录及Debug模式详细讲解
  • 高并发项目-用户登录基本功能
  • kotlin基础之泛型和委托
  • awtk踩坑记录二:移植jerryscript到awtk design项目
  • 正邦科技(day2)
  • 技术架构设计指南:从需求到实现
  • 【数据结构:排序算法】堆排序(图文详解)
  • git 派生仓库怎么同步主仓库的新分支
  • 对比方案:5款知识中台工具的优缺点详解
  • 第16章-超声波跟随功能 基于STM32的三路超声波自动跟随小车 毕业设计 课程设计
  • 创新案例 | 持续增长,好孩子集团的全球化品牌矩阵战略与客户中心设计哲学
  • ResNet 原理剖析以及代码复现
  • 数据结构(十)图
  • 四数之和-力扣
  • JS 中怎么删除数组元素?有哪几种方法?
  • Git如何将pre-commit也提交到仓库
  • vmware中Ubuntu虚拟机和本地电脑Win10互相ping通
  • 比较含退格的字符串-力扣