《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 并不像表面上看起来那么简单.由于浏览器中充斥着隐藏的 ...
随机推荐
- RandomAccessFile出现中文乱码问题
之前程序里调用了RandomAccessFile的writeByte(String str)方法,报文里存在中文的时候出现了乱码 后面换成了 write(byte b[])或writeBytes(by ...
- Matlab imshow, image, imagesc 三者详细分析
1.显示RGB图像 相同点:这三个函数都是把m*n*3的矩阵中的数值当做RGB值来显示的. 区别:imshow将图像以原始尺寸显示,image和imagesc则会对图像进行适当的缩放(显示出来的尺寸大 ...
- 快速搭建Docker Registry私有仓库
前提条件: 服务器已经安装Docker(我的服务器是CentOS 7) 服务器已经安装Docker Compose 满足以上条件时就可以开始搭建了: 1. 生成用户密码文件:(运行下面命令后会在当前目 ...
- 初识C语言(五)
自定义函数 C语言提供了大量的库函数(右侧资料下载中有),比如stdio.h提供输出函数,但是还是满足不了我们开发中的一些逻辑,所以这个时候需要自己定义函数,自定义函数的一般形式: 注意: 1.[]包 ...
- ad9361自测试校准
#include "config.h" #include "CONFIG_FPGA_ALL.h" #include "xparameters.h&qu ...
- 基于Vue2.x的小米商城移动端项目
初学vue已经有一段时间,为了检验自己的学习成果,决定做一个项目作为一个阶段性总结,项目花了差不多半个月时间,目前实现了7个页面,商城的主要功能基本实现,代码已经放到github上面. 这个项目把大部 ...
- Python中的命名空间概念
python使用命名空间记录变量.python中的命名空间就像是一个dict,key是变量的名字,value是变量的值. python中,每个函数都有一个自己的命名空间,叫做local namespa ...
- mybatis和hibernate中的懒加载
概念:所谓懒加载就是延时加载,延迟加载.什么时候用懒加载呢,我只能回答要用懒加载的时候就用懒加载.至于为什么要用懒加载呢,就是当我们要访问的数据量过大时,明显用缓存不太合适,因为内存容量有限 ,为了减 ...
- Python 常用Web框架的比较
转载来自:https://www.cnblogs.com/sunshine-1/p/7372934.html 从GitHub中整理出的15个最受欢迎的Python开源框架.这些框架包括事件I/O,OL ...
- input autocomplete属性设计输入框自动联想(php实现)
因为客户临时要求加一个输入框自动联想,就开始了解这块.结合网上总结最难的一点就是找好对应的js版本以及相应的jQuery-ui: 以下是我用的版本,以及连接地址: jQuery的js文件: <s ...