`

HTML5中script的async属性

 
阅读更多

HTML4.01中的script标签属性

HTML4.01 为script标签定义了5个属性:

  • charset 可选。指定src引入代码的字符集,大多数浏览器忽略该值。
  • defer 可选。延迟脚本执行,相当于将script标签放入页面body标签的底部。除IE和较新版本的Firefox外,其他浏览器并未支持。
  • language 已废弃。大部分浏览器会忽略该值。
  • src 可选。指定引入的外部代码文件,不限制后缀名。
  • type 必选。指定脚本的内容类型(MIME类型)。现实中通常不指定该值也可以,浏览器会默认当作text/javascript类型来解释执行。

HTML5中的script属性

script标签在 HTML5 中除了具备 HTML5标准属性 以外,与HTML4.01相比移除了language属性,修改了type属性为可选的(默认text/javascript),并新增了一个属性async。

async属性的作用

定义脚本是否异步执行,取值true或false。

async如果指定为true,脚本会在页面渲染显示的过程中解析执行(浏览器会判断该脚本是否处于可用状态),这是一个很有意思也很实用的功能。

现在的script是怎样的?

1、把它放在head标签内。在下载script引入的外部脚本时,浏览器处于阻塞状态,网络不好或者script文件过大时,页面处于空白停顿状态,体验是并不够好。

2、把它放入页面底部。这是大家公认的提高前端页面性能和体验的方法,但还是存在一定的问题,放在页面底部的脚本是要等到页面文档流下载完毕才去下载、执行,页面中的交互会存在一个延迟的时间去实现。虽然页面显示时间变短了,但交互却被延后了。体验也不够好。

3、按需执行。在head标签内引入部分公共脚本,在每一个需要交互的HTML元素之后插入script立即执行,需要特定条件才执行的脚本放到页面最底部。这也不是一个完美的解决方案,一则页面内穿插过多的script标签引起维护不便,二来底部脚本还未加载完时用户便触发了某个条件该怎么办?虽有方法实现,但体验仍不够好。

支持async属性之后改变了什么?

async属性就是解决上面这些问题的,这样我们就可以在head标签内插入script,脚本与文档同时下载,脚本、文档可用时便执行。

async与defer

摘抄 HTML5手册 的解释,很好理解:

如果 async 属性为true,则脚本会相对于文档的其余部分异步执行,这样脚本会可以在页面继续解析的过程中来执行。如果 async 属性为false,而 defer 属性为true,则脚本会在页面完成解析时得到执行。如果 async  defer 属性均为false,那么脚本会立即执行,页面会在脚本执行完毕继续解析。

改变往往意味着丢掉不合时宜的,增加满足用户新需求的功能,HTML5很多新增特性让人期待,随着新装机安装windows7带来的IE版本的提升,距离IE6倒下的时刻不会太远了,未来的浏览器是否还是IE的天下也不好说。

参考资料:

  1. http://developer.yahoo.com/performance/rules.html#js_bottom
  2. http://www.w3school.com.cn/html5/html5_script.asp
  3. http://www.w3.org/TR/html4/interact/scripts.html
  4. http://www.w3.org/TR/2010/WD-html5-20101019/scripting-1.html#script
  5. http://www.csser.com/board/4f3f516e38a5ebc978000514
分享到:
评论

相关推荐

    script的async属性以非阻塞的模式加载脚本

    1.HTML5实现了script的async属性,这个新的属性可以让js在浏览器中以非阻塞的模式加载,另外script还有一个defer属性,这个属性目前所有浏览器都已实现(除了firefox和chrome的早期版本),IE这方面做得好,从一开始...

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

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

    HTML5 script元素async、defer异步加载使用介绍

    异步加载,可以理解为无阻塞并发处理,过去我们使用各种JavaScript技巧来做这种事情,现在WebKit为HTML5实现了SCRIPT标签的async异步属性,感兴趣的朋友可以了解下

    HTML5 对各个标签的定义与规定:script

    script 标签用于定义客户端脚本,比如 JavaScript。 除全局属性之外有如下属性 src 定义指向包含脚本的文件的 URL(这样您就可以引用某个包含脚本的文件,而不是直接把脚本插入您的 HTML 文档中) async 定义脚本...

    js的[defer]和[async]属性

    [defer] 可以在[removed]中加入defer属性,告诉浏览器这段script不必立即执行,那么浏览器就会在完全载入文档之后再执行这个script,相当于[removed],但它比...[removed]标签的async属性——HTML5新的异步、并行

    浅谈HTML5 defer和async的区别

    HTML4.01为[removed]定义了6个属性,包括defer和async。defer和async都是可选的,且只对外部脚本文件有效。 一、当浏览器解析到script脚本,没有defer或async时: [removed][removed] 浏览器会立即加载并执行指定...

    浏览器环境下JavaScript脚本加载与执行探析之defer与async特性

    本文结合已有的一些文章以及MDN文档中对两个特性的阐述,对defer和async进行更全面的研究和总结,希望能够帮助开发者更好地掌握这两个特性。 1 引言 在《浏览器环境下JavaScript脚本加载与执行探

    form-async:易于使用的库,提供表单更改时的缩写发送

    保存任何HTML表单元素支持内容可编辑属性完全定制如果ajax请求失败,请重试功能将表单元素作为字段组发送提供在发送Ajax请求之前验证更改的方法经过严格测试安装$ npm install form-async 我们建议从npm安装,然后...

    在HTML中使用JavaScript实例代码

     在HTML5中script主要有以下几个属性:async,defer,charset,src,type, async(可选):  关键词:异步脚本,外部文件,立即下载;  当标签中包含这个属性时会立即下载脚本(外部文件),只对外部脚本文件...

    javascript学习笔记(一)基础知识

    基本概念 javascript是一门解释型的语言,浏览器充当解释器。 js执行引擎并不是一行一行...html5为[removed]定义了async属性。整个属性与defer属性类似,都用于改变处理脚本的行为。同样,与defer类似,async只适用于外

    2.1 认识script和基本数据类型

    在html页面中插入JavaScript的方法主要是使用script元素,他有几个属性:  async: 表示应立即下载脚本,但不应妨碍页面中的而其他操作,比如下载资源或等待其他等待加载的脚本,只对外部脚本有效。  defer: 表示...

    angularjs-d3-chartbuilder:Quartz Chartbuilder 的克隆,带有 angular 和 d3,用于图表类型的模块化构建

    如果您只想嵌入单个图表,您可以使用包含的内联嵌入脚本,将两个数据属性替换为您从 chartbuilder 保存的文本后,将其粘贴到您的 html 中。 <script async data-chart='[CHART-JSON-STRING]' data-template='...

    pr-preview:将预览和差异添加到规格拉取请求

    公关预览 PR Preview使...已知的问题使用async属性包含ReSpec时,它会出现竞争状况问题。 而是使用defer属性,如下所示: < script src =" https://www.w3.org/Tools/respec/respec-w3c-common " class =" remove

    PromiseFundementals:关于Java中的Promise的字节和比特

    PromiseFundementals :dashing_away: :hundred_points: :hollow_red_circle: 关于Java中的Promise的字节和比特 :hollow_red_circle: :check_mark: 您可以执行特定的javascript文件(不适用于html文件)作为node ...

    JS_basics:前端练习 内容为自己的练习题

    Javascript html css vue题目 引自:前端小哥CSS HTML1.行内元素/块级元素,非替换元素/替换元素★★★2.img标签 的title和alt属性★★3.meta标签 ★★4.DOCTYPE 标签★★★5.script标签 的defer和async★6.W3C盒...

    XML轻松学习手册--XML肯定是未来的发展趋势,不论是网页设计师还是网络程序员,都应该及时学习和了解

    XML创建了标识,而DOM的作用就是告诉script如何在浏览器窗口中操作和显示这些标识 上面我们已经简要的讲述了一些XML的基本原理,我们来看看它们之间的关联以及它们是如何工作的,先看这里一张图: 1.XML描述...

    js使用小技巧

    clip:rect(5px 15px 15px 5px)"> 获取选中内容 document.selection.createRange().duplicate().text 自动完成功能 打开该功能 关闭该功能 窗口最大化 (window.screen.width - 4,window.screen.height-...

    good-map:Google Maps JavaScript API的简单自定义元素包装器

    script src =" good-map.js " async defer > </ script > 或者,使用HTML导入以包含 :< link rel =" import " href =" good-map.html " >用法在页面上的任意位置创建一个元素。 确保使用display: ...

    aria-tips:使用 aria 进行声明性实例化的简单工具提示组件

    咏叹调提示使用 aria 进行声明性实例化的简单工具提示组件。 我们经常需要一些工具提示来获取有关元素功能的额外信息。 你猜怎么着…?... script async src =" lib/aria-tips.js " onload =" AriaT

Global site tag (gtag.js) - Google Analytics