原文章:https://segmentfault.com/q/1010000000640869

本文章讲解几个点:

  • <script>  标签中 的 defer 和 async 是什么;
  • 使用 defer 可以解决什么问题

defer 和 async 是 <script> 标签中的属性。

当浏览器碰到 script 脚本的时候,有下面三种情况:

一、一般情况:(立即脚本、无延缓也没异步)

<script src="script.js"></script>

没有 defer 或 async,浏览器会立即加载并执行指定的脚本,“立即”指的是在渲染该 script 标签之下的文档元素之前,也就是说不等待后续载入的文档元素,浏览器读到脚步就加载并执行。脚本执行完,再继续解析剩下的 html 未解析的部分。

二、异步:asyn

<script async src="script.js"></script>

有 async,加载和渲染后续文档元素的过程将和 script.js 的加载与执行并行进行(异步)。

三、延缓:defer

<script defer src="myscript.js"></script>

有 defer,加载后续文档元素的过程将和 script.js 的加载并行进行(异步),但是 script.js 的执行要在所有元素解析完成之后,** DOMContentLoaded 事件触发之前完成。

【PS: ** DOMContentLoaded:参见:DOMContentLoaded 事件 和 load 事件(文档加载后触发)

https://blog.csdn.net/weixin_41796631/article/details/89704728】

蓝色线代表网络读取,红色线代表执行时间,这俩都是针对脚本的;绿色线代表 HTML 解析。

此图告诉我们以下几个要点:

  1. defer 和 async 在网络读取(下载)这块儿是一样的,都是异步的(相较于 HTML 解析)
  2. 它俩的差别在于脚本下载完之后何时执行,显然 defer 是最接近我们对于应用脚本加载和执行的要求的
  3. 关于 defer,此图未尽之处在于它是按照加载顺序执行脚本的,这一点要善加利用
  4. async 则是一个乱序执行的主,反正对它来说脚本的加载和执行是紧紧挨着的,所以不管你声明的顺序如何,只要它加载完了就会立刻执行
  5. 仔细想想,async 对于应用脚本的用处不大,因为它完全不考虑依赖(哪怕是最低级的顺序执行),不过它对于那些可以不依赖任何脚本或不被任何脚本依赖的脚本来说却是非常合适的,最典型的例子:Google Analytics

使用 defer 可以解决的问题:

很多人也都遇到过这样的问题,需要直接执行别且操作DOM对象的js 总是报找不到对象的错误,原因大家也都知道就是页面还有没有加载完毕,js的操作对象还在下载中

请注意两点:

1、不要在defer型的脚本程序段中调用document.write命令,因为document.write将产生直接输出效果。
2、而且,不要在defer型脚本程序段中包括任何立即执行脚本要使用的全局变量或者函数。

一个常用的优化性能的方法是:当脚本不需要立即运行时,在<SCRIPT>标签中设置“defer”属性。 (立即脚本没有被包含在一个function块中,因此会在加载过程中执行。) 设置“defer”属性后,IE就不必等待该脚本装载和执行完毕。这样页面加载会更快。一般来说,这也表明立即脚本最好放在 function 块中,并在 document或者 body 对象的 onload 句柄中处理该函数。在有一些脚本需要依赖用户操作而执行时----例如点击按钮,或者移动鼠标到某个区域----使用该属性非常有用。但当有一些脚本需要在页面加载过程中或加载完成后执行,使用defer属性得到的好处就不太大。

script中的defer属性默认情况下是false的。按照DHTML编程宝典中的描述,对于Defer属性是这样写的:
Using the attribute at design time can improve the download performance of a page because the browser does not need to parse and execute the script and can continue downloading and parsing the page instead.
      也就是说:如果是编写脚本的时候加入defer属性,那么浏览器在下载脚本的时候就不必立即对其进行处理,而是继续对页面进行下载和解析,这样会提高下载的性能。
      这样的情况有很多种。比如你定义了很多javascript变量,或者在引用文件(.inc)中写了很多的脚本需要处理,那不妨在这些脚本中加入defer属性,对性能的提高肯定有所帮助。
举例如下:

<script language="javascript" defer>
var object = new Object();
....
</script>

因为defer属性默认是为false的,那么在这里

<script language="javascript" defer>

显式声明defer属性后等同于

<script language="javascript" defer=true>
声明了defer属性之后,需要判断是否有别的变量引用了defer脚本块中的变量,否则的话会导致脚本错误的产生。

script 脚本标签中 defer 和 async (延缓 和 异步)相关推荐

  1. script标签中defer和async的区别

    defer 和 async属性都是去异步加载外部的JS脚本文件,它们都不会阻塞页面的解析,其区别如下: defer为true:延迟加载脚本,在文档完成解析完成开始执行,并且在DOMContentLoa ...

  2. html5中defer的属性,HTML5中defer和async的比较

    在网站页面中,通常需要引入外部js资源,然而外部的js资源可能导致DOM阻塞,影响页面加载速度.通过异步或者延迟执行js,可以做到引用外部js资源而不阻塞DOM的目的.用法是直接在script标签中使 ...

  3. [暑假]<script>标签中的type属性详解

    type属性是必须写的属性吗? 不写的情况: <script>标签中的type属性不是必须写的属性, 因为按照惯例,这个值始终都是"text/javascript", ...

  4. script 标签的 defer 与 async 属性

    前言 在面试的时候,经常会遇到一道经典的面试题: 如何优化网页加载速度? 常规的回答中总会有一条: 把 css 文件放在页面顶部,把 js 文件放在页面底部. 那么,为什么要把 js 文件放在页面的最 ...

  5. SAP UI5 的 sap-ui-bootstrap script 脚本标签各属性解析

    看这段测试代码: <!DOCTYPE html> <html> <head><meta charset="utf-8"><ti ...

  6. script标签中的defer和async属性

    默认情况下,浏览器是同步加载 JavaScript 脚本,即渲染引擎遇到<script>标签就会停下来,等到执行完脚本,再继续向下渲染.如果是外部脚本,还必须加入脚本下载的时间. 如果脚本 ...

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

    向html页面中插入javascript代码的主要方法就是通过script标签.其中包括两种形式,第一种直接在script标签之间插入js代码,第二种即是通过src属性引入外部js文件.由于解释器在解 ...

  8. script 标签中的defer 和 async 属性

    浏览器在解析 HTML 的时候,如果遇到一个没有任何属性的 <script> 标签 ,就会暂停解析,先发送网络请求获取该 JS 脚本的代码内容,然后让 JS 引擎执行该代码,当代码执行完毕 ...

  9. defer和async

    首先先了解一下页面的加载渲染过程 页面的加载和渲染过程 1.首先浏览器会通过HTTP请求服务器获取HTML文件 2.然后就开始从上到下解析HTML,构建DOM 3.如果在解析过程中,碰见了外联的样式声 ...

最新文章

  1. python项目了解_神级程序员都是这样来开源 Python 项目!今天算是涨知识了!
  2. 基于Python的频谱分析(二)——频谱泄露
  3. Java 11 快要来了,编译 运行一个命令搞定!
  4. Python简明教程
  5. boot jndi数据源 spring_spring boot多数据源配置(mysql,redis,mongodb)实战
  6. 联想拯救者y7000电池耗电快_游戏新选择:联想2020款拯救者Y7000/R7000爆料
  7. 使用 RMAN 同步数据库
  8. Java开发环境!java写猜数字小游戏
  9. C++ std:: 的坑
  10. 我的小导师-天津大学张梅山老师要招NLP方向的研究生啦!
  11. 怎么用QQ查看对方IP
  12. SqList *L 和 SqList * L的一些理解以及多重指针的简单应用
  13. REST服务简介和实践
  14. 【元胞自动机】基于matlab元胞自动机地铁火灾疏散模型【含Matlab源码 246期】
  15. Python面向对象三大特征之封装
  16. ajax php 源码,ThinkPHP Ajax 实例源代码_ThinkPHP教程
  17. DM642的PCI驱动编程笔记:遍历一块内存空间的源码
  18. OSChina 周六乱弹 —— 周末万岁!
  19. excel阅读器Android,Excel阅读器
  20. ubuntu18.04 LORD 3DM-GX5-AHRS + ros驱动安装

热门文章

  1. Mac 没法登陆,进入Safe boot模式
  2. #pragma用法详解
  3. java汉字转拼音和获取汉语拼音首字母
  4. listview qt 选中内容_演练: 操作Qt应用中的QListView
  5. 67 step to success
  6. 【干货】剖析大数据分析方法论的几种理论模型(文末有福利哦)
  7. html2canvas+jsPDF实现横向打印iframe中的内容
  8. 安装PS 无法选择路径
  9. Qt鼠标相对位置、绝对位置、窗口位置、控件位置、控件大小、控件绝对位置
  10. 负电阻_三极管单管震荡电路