原文章: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. 赖江山:生态学研究都在用哪些R包?
  2. java中为什么需要常量和变量的区别_Java中的变量和常量
  3. 【正一专栏】运动式的创建文明城市要着干嘛
  4. 入中继限呼的方法之一
  5. HTML5本地存储 localStorage
  6. AspNetCore 基于AOP实现Polly的使用
  7. python 内置函数 builtins_python学习笔记(七)——内置函数
  8. 字节跳动算法工程师总结:java自学路线及推荐书籍
  9. centos 7 php目录权限设置密码,Linux系统中(CentOS 7)的用户和权限管理
  10. 单片机C语言程序设计实训100例:基于AVR+proteus仿真pdf
  11. TURN协议简要介绍
  12. macOS 曝可获取用户密码的 0day 漏洞;Fedora logo 改版三个候选方案
  13. 运算放大器的简要理解
  14. dis ospf peer 输出
  15. Dell R640服务器centos系统增加万兆网卡设置
  16. 再见李佳奇,菜鸟哥用Python也能帮小姐姐选择口红啦!
  17. java定义一个盒子类box_C++定义一个Box(盒子)类 看完你就知道了
  18. 弯管机编程软件电脑版_奥信编程电脑版
  19. Vos如何在外地号码前自动加0,本地号码前不加0
  20. 数据结构和算法学习指南

热门文章

  1. 2021-9-28 数据结构学习 第四章 - 栈 和 队列【1024Re】
  2. linux环境中英文切换配置以及乱码问题
  3. 经常被问退休金多少,怎么答
  4. Python3 迁移怨声载道
  5. CANoe 入门 _CAPL编程
  6. Numpy简易教程7——读/写文件
  7. CSS中的圆角与倒角
  8. axios发送请求,后端报错:所需的防伪表单字段“__RequestVerificationToken”不存在
  9. 微信高级群发之预览接口
  10. 电缆 电流_如何不用电缆观看每项运动(运动返回时)