《JavaScript高级程序设计(第3版)》阅读总结记录第二章之在HTML中使用JavaScript
本章目录:
2.1 <script> 元素
2.1.1 标签的位置
2.1.2 延迟脚本
2.1.3 异步脚本
2.1.4 在XHTML 中的用法
2.1.5 不推荐使用的语法
2.2 嵌入代码与外部文件
2.3 文档模式
2.4 <noscript> 元素
2.5 总结
本章主要内容:
使用 <script> 元素
嵌入脚本与外部脚本
文档模式对 JavaScript 的影响
考虑禁用 JavaScript 的场景
2.1 <script> 元素
可选元素:async 、charset 、defer 、src 、type
已废弃元素:language
<script type="text/javascript" charset="UTF-8" language="javascript"></script>
有 charset ,表示通过 src 属性指定的代码的字符,(由于此属性被大多浏览器忽略,因此很少用);
有 language ,已废弃;
有 type ,可看是 language 的替代属性;表示编写代码的脚本语言的内容类型(也称为MIME类型)。
<script src="script.js"></script>
有 src ,表示包含要执行代码的外部文件;
没有 async 或 defer ,浏览器会立即加载并执行指定的脚本,“立即”指的是在渲染该 script 标签之下的文档元素之前,也就是说不等待后续载入的文档元素,读到就加载并执行。
<script async src="script.js"></script>
有 async ,加载和渲染后续加载文档的过程将和 script.js 的加载与执行并行进行(异步)。
<script defer src="script.js"></script>
有 defer ,加载后续文档元素的过程将和 script.js 的加载并行进行(异步),但是 script.js 的执行要在所有元素解析完成之后,DOMContentLoaded 事件触发之前完成。
注:
1):在使用 <script> 嵌入JavaScript代码时,不可在代码中的任何地方出现“</script>”字符串,因为按照解析嵌入式代码的规则,当浏览器遇到字符串“</script>”的时候会认为是结束的 </script>标签。
解决方法: 通过转义字符“/”
2):<script src="index.js"> 此写法只是在 XHTML 文档中有效,不可在 HTML 文档中使用,因这种语法不符合 HTML 规范,而且也得不到有些浏览器的正确解析(尤其是 IE )。
3):带有 src 属性的 <script> 元素不应在其 <script> 和 </script> 标签之间再包含额外的 JavaScript 代码。否则只会下载并执行外部脚本文件,嵌入的代码会被忽略。
2.2.1 标签的位置
按照传统做法应将所有的 <script> 元素都应该放在 <head> 元素中,如:
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>javaScript test</title>
<script src="index.js"></script>
<script src="main.js"></script>
</head>
<body>
<!-- 这里是内容 -->
</body>
</html>
这种做法的目的是把所有的外部文件(包括 CSS 文件和 JavaScript 文件)的引用都放在相同的地方。但如果有多个 JavaScript 代码的页面时会导致浏览器在呈现页面时出现明显的延迟,在此期间浏览器窗口将是一片空白显示。为避免此问题现代 Web 应用程序一般会把全部 JavaScript 引用放在 <body> 元素中页面内容的后面,如:
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>javaScript test</title>
</head>
<body>
<!-- 这里是内容 -->
<script src="index.js"></script>
<script src="main.js"></script>
</body>
</html>
这样在解析包含 JavaScript 代码之前页面将会完全呈现在浏览器中,用户打开页面的速度也会加快。
2.1.2 延迟脚本
HTML 4.0 为 <script> 标签定义了 defer 属性,这个属性的用途是表明脚本在执行时不会影响页面的构造,即使我们按照传统的写法将 <script> 元素放在了文档的 <head> 元素中,其包含的脚本延迟到浏览器遇到 </html> 标签之后再执行,也就是说,脚本会被延迟到整个页面都解析完毕后再运行。
注:
defer 只适用于外部脚本文件。
2.1.3 异步脚本
HTML5 为 <script> 标签定义了 async 属性,这个属性与 defer 属性类似,都用于改变处理脚本的行为。与 defer 不同的是,标记为 async 的脚本并不保证按照指定它们的先后顺序执行。如:
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="content-type" content="text/html;charset=utf-8">
<title>javaScript test</title>
<script src="index.js" async="async" type="text/javascript"></script>
<script src="main.js" async="async" type="text/javascript"></script>
</head>
<body>
<!-- 这里是内容 -->
</body>
</html>
以上使用了 async 的代码中,main.js 文件有可能会在 index.js 文件之前执行。
2.1.4 在XHTML中的用法
可扩展超文本标记语言,即 XHTML (Extensible HyperText Markup Language),是将 HTML 作为 XML 的应用重新定义的一个标准。编写 XHTML 代码的规则要比编写 HTML 严格得多。在 HTML 中,有特殊的规则用以确定 <script> 元素中的哪些内容可以被解析,但这些特殊的规则在 XHTML 中不适用。作为一名前端开发人员,HTML5正在快速地被使用,建议在学习开发中遵循 HTML5 标准。
2.1.5 不推荐使用的写法
不推荐使用语法是针对早期<script> 元素与传统元素 HTML 的解析规则有冲突而编写的语法。如:
以上写法是针对 Mosaic 对 JavaScript 的不支持而编写的方案。
2.2 嵌入代码与外部文件
在 HTML 中嵌入 JavaScript 代码虽然没有问题,但最好的做法还是尽可能的使用外部文件来包含 JavaScript 代码。
使用外部文件的优点:
(1) 可维护性
(2) 可缓存
(3) 适应未来
2.3 文档模式
IE5.5 通过使用文档类型(docutype)引入了文档模式的概念。最初的两种文档模式是:混杂模式(quirks mode)和标准模式(standards mode)。
混杂模式会让 IE 的行为与(包含非标准特性的)IE5 相同,而标准模式则让 IE 的行为更接近标准模式行为。
两种模式主要影响 CSS 内容的呈现,在某些情况下也会影响到 JavaScript 的解释执行。
而后期,IE又提出一种准标准模式(almost standards mode)。除了在处理图片间隙的的时候有些不标准其他模式下的浏览器特性都是符合标准的。
对于标准模式,可通过下面任意一种文档类型来开启:
<!--HTML 4.01 严格型 -->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd"> <!--XHTML 1.0 严格型 -->
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> <!-- HTML 5 -->
<!DOCTYPE html>
对于准标准模式,可通过文档类型来开启:
<!--HTML 4.01 过渡型 -->
<!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd"> <!--HTML 4.01 框架集型 -->
<!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <!-- XHTML 1.0 过渡型 -->
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Frameset//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd"> <!-- XHTML 1.0 框架集型 -->
<!DOCTYPE html PUBLIC
"-//W3C//DTD XHTML 1.0 Frameset//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-frameset.dtd">
总之,准标准模式和标准模式很接近,当我们提到“标准模式的时候”,也有可能是其中的一种,检测文档模式的时候也不会发现什么不同。
2.4 <noscript>元素
<noscript> 元素主要针对不支持 JavaScrip 的浏览器来显示替代的内容,此元素可包含能够出现文档 <body> 中的任何HTML元素 __ <script> 元素除外。
包含在 <noscript> 元素中的内容只有在以下两种情况才会显示出来:
(1):浏览器不支持脚本;
(2):浏览器支持脚本,但脚本被禁用。
<html>
<head>
<title>noscript age</title>
<script type="text/javascript" defer="defer" src="js/jquery-1.11.1.min.js"></script>
<script type="text/javascript" defer="defer" src="js/jquery-1.11.1.min.js"></script>
</head>
<body>
<noscript>
<p>此页面需要浏览器支持(启用)JavaScript 。</p>
</noscript>
</body>
</html>
此页面会在脚本无效的情况下向用户显示一条信息,而启用了脚本的浏览器中,用户将看不到这条信息。
2.5 小结
(1):将 JavaScript 插入到 HTML 页面中要使用 <script> 元素;
(2):在包含外部 JavaScript 文件时,必须将 src 属性设置为指向相应文件的 URL;
(3):所有的 <script> 元素都会按照它们在页面中出现的先后顺序依次被解析,
(4):由于浏览器会先解析不使用 defer 属性的 <script> 元素中的代码,然后再解析后面的内容,所以一般把 <script> 元素放在页面最后,即主要内容后面,</body> 标签之前;
(5):使用 defer 属性可以让脚本在文档完全呈现之后再执行;
(6):使用 async 属性可以表示当前脚本不必等待其他脚本,也不必阻塞文档呈现。
如果文中有错误,非常感谢您指出,但请不要刻薄诋毁。
文章我会尽量添加一些实用的例子,方便理解阅读。
本文属于连载性随时更新文章。
个人属于中级程序媛,现于成都某公司任职Web前端开发,希望通过自己的学习然后巩固提升我的技术,大神勿喷,谢谢 /haha
《JavaScript高级程序设计(第3版)》阅读总结记录第二章之在HTML中使用JavaScript的更多相关文章
- JavaScript高级程序设计第三版-读书笔记(1-3章)
这是我第一次用markdown,也是我第一次在网上记录我自己的学习过程. 第一章 JavaScript主要由以下三个不同的部分构成 ECMAScript 提供核心语言功能 DOM 提供访问 ...
- JavaScript高级程序设计第三版.CHM【带实例】
从驱动全球商业.贸易及管理领域不计其数的复杂应用程序的角度来看,说 JavaScript 已经成为当今世界上最流行的编程语言一点儿都不为过. JavaScript 是一种非常松散的面向对象语言,也是 ...
- JavaScript 高级程序设计 (第4版) 思维导图/脑图 All In One
JavaScript 高级程序设计 (第4版) 思维导图/脑图 All In One JavaScript 高级程序设计 (第4版) 思维导图下载 JavaScript 高级程序设计 (第4版) 脑图 ...
- 2.1 <script>元素【JavaScript高级程序设计第三版】
向 HTML 页面中插入 JavaScript 的主要方法,就是使用<script>元素.这个元素由 Netscape 创造并在 Netscape Navigator 2 中首先实现.后来 ...
- javascript高级程序设计第三版书摘
在HTML 中使用JavaScript <script>元素 在使用<script>元素嵌入 JavaScript 代码时,只须为<script>指定 type 属 ...
- 《Javascript高级程序设计第3版》精华总结
一.JavaScript简介 1.1 javascript简史 1.2 javascript实现 + javascript是一种专为网页交互而设计的一种脚本语言,javascript由三大部分组成 ...
- 【读书笔记】读《JavaScript高级程序设计-第2版》 - 非函数部分
章节列表: 第08章:BOM 第09章:客户端检测 第10章:DOM 第11章:DOM2和DOM3 第12章:事件 第13章:表单脚本 第14章:错误处理与调试 第17章:Ajax和JSON第20章: ...
- DOM 操作技术【JavaScript高级程序设计第三版】
很多时候,DOM 操作都比较简明,因此用JavaScript 生成那些通常原本是用HTML 代码生成的内容并不麻烦.不过,也有一些时候,操作DOM 并不像表面上看起来那么简单.由于浏览器中充斥着隐藏的 ...
- 10.2 DOM 操作技术【JavaScript高级程序设计第三版】
很多时候,DOM 操作都比较简明,因此用JavaScript 生成那些通常原本是用HTML 代码生成的内容并不麻烦.不过,也有一些时候,操作DOM 并不像表面上看起来那么简单.由于浏览器中充斥着隐藏的 ...
随机推荐
- C#调用Bartender打印
BarTender是一款优秀的条形码打印软件,可以支持很多种类型的条形码设计和打印,具体大家可参考他的官网(http://www.seagullscientific.com/aspx/products ...
- JMX - JMX定义
JMX定义 JMX超详细解读 https://www.cnblogs.com/dongguacai/p/5900507.html 开源框架是如何通过JMX来做监控的(一) - JMX简介和Standa ...
- [Kubernetes]资源模型与资源管理
作为 Kubernetes 的资源管理与调度部分的基础,需要从它的资源模型说起. 资源管理模型的设计 我们知道,在 Kubernetes 里面, Pod 是最小的原子调度单位,这就意味着,所有和调度和 ...
- Appnium-API-Status
Status Java:// TODO Python:selenium.webdriver.common.utils.is_url_connectable(port) Description Retu ...
- 阻塞IO,非阻塞IO,IO多路复用模型
#服务端 import socket sk = socket.socket() sk.bind(('127.0.0.1',8080)) sk.listen() while True: conn, ad ...
- IIS+nginx反向代理 负载均衡
本文没有过多的讲述,只讲述重点地方.由这两个转自的文章进行中和 1.nginx+iis实现负载均衡(这篇文章主要是有第2篇文章的工具) 2.nginx+iis使用(这篇文章讲得很详细,配置文件直接复制 ...
- PCB开钢网不容忽视的问题
作为PCB工程师,或许你已经出过很多次的钢网文件,但却不一定了解出钢网有哪些要求. 1.首先我们来看下钢网的实物图,就是一块薄薄的钢板,钢网上有很多焊盘孔.把钢网盖在PCB板上后,这些焊盘孔就会和PC ...
- MapReduce流量统计
准备数据access.log 要用到的只有第二个手机号,倒数第三上行流量,倒数第二下行流量. 1363157985066 13726230503 00-FD-07-A4-72-B8:CMCC 120. ...
- CentOS7各个版本镜像下载地址
# CentOS7.6 下载地址 # CentOS-7-x86_64-DVD-1810.iso CentOS 7.6 DVD 版 4G http://mirrors.163.com/centos/7. ...
- struts2第一章-基本用法
一.struts简介 1.回顾 MVC M-model模型层 V-view 视图层 前端界面 C-controller 控制层 struts2: Apache提供的开源的控制层框架,相当于servl ...