JavaScript高级程序设计学习笔记第二章
1.向 HTML 页面中插入 JavaScript 的主要方法,就是使用<script>元素
2.HTML 4.01中定义了<script>元素的六个属性(方便记忆,可将6个属性分为3组)
第一组:
- async:可选。表示应该立即下载脚本,但不应妨碍页面中的其他操作,比如下载其他资源或等待加载其他脚本。只对外部脚本文件有效。(使用<script>不属于外部脚本)
- defer:可选。表示脚本可以立即下载,但是延迟到文档完全被解析和显示之后再执行。只对外部脚本文件有效。
第二组:
- language:已废弃。原来用于表示编写代码使用的脚本语言(如 JavaScript、JavaScript1.2或 VBScript)。大多数浏览器会忽略这个属性,因此也没有必要再用了。
- type:可选。可以看成是 language 的替代属性;表示编写代码使用的脚本语言的内容类型(也称为 MIME 类型)。
第三组:
- charset:可选。表示通过 src 属性指定的代码的字符集。由于大多数浏览器会忽略它的值,因此这个属性很少有人用。
- src:可选。表示包含要执行代码的外部文件。可以是同一服务器上的文件,也可以是任何域上的文件。
3.使用<script>元素的方式有两种:直接在页面中嵌入 JavaScript 代码(使用<script>元素)和包含外部 JavaScript文件(使用<script>标签的src属性)。
4.使用嵌入式javascript代码的时候,代码内容中不能出现“</script>”字符串,因为浏览器遇到“</script>”字符串,就会认为是结束的</script>标签。如果一定要有,则使用准义字符<\/script>。
5.在解析内嵌 JavaScript 代码时,包含在<script>元素内部的 JavaScript 代码将被从上至下依次解释,解析外部 JavaScript 文件(包括下载该文件)时,页面的处理也会暂时停止。
6.带有 src 属性的<script>元素不应该在其<script>和</script>标签之间再包含额外的 JavaScript 代码。如果包含了嵌入的代码,则只会下载并执行外部脚本文件,嵌入的代码会被忽略。
7.<script>标签包含的内容一般放在<head>标签内部,但由于javascript代码全部被下载、解析和执行情况下,页面会暂停动作,而浏览器要遇到<body>标签时才会呈现内容,如果放在<head>标签里,那么页面会有一段时间的空白显示,所以应该放在</body>标签之前,这样的页面的内容就完全呈现出来。
8.如果有两个外部脚本都有defer属性(延迟脚本),理论上第一个脚本要先于第二个脚本执行,并且两个脚本会先于 DOMContentLoaded 事件执行。但实际上延迟脚本并不一定会按照顺序执行,也不一定会在 DOMContentLoaded 事件触发前执行,因此最好只包含一个延迟脚本。
9.标记为 async 的脚本(异步脚本)并不保证按照指定它们的先后顺序执行,建议异步脚本不要在加载期间修改 DOM。一定会在页面的 load 事件前执行,但可能会在 DOMContentLoaded 事件触发之前或之后执行。
10.文档模式:
- 严格模式:
<!-- HTML 4.01 严格型 -->
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"
"http://www.w3.org/TR/html4/strict.dtd">
- 过渡模式:比严格模式多了一些内容,例如允许标签的内置CSS属性
<!-- HTML 4.01 过渡型 -->
<!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
- 框架模式:在过渡模式的基础上可以使用<frame>标签,添加框架
<!-- HTML 4.01 框架集型 -->
<!DOCTYPE HTML PUBLIC
"-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd">
XHTML比HTML 4.01更加严格一些,也有三种模式,html5只有一种模式。
11.使用<noscript>元素可以再浏览器不支持会禁用的javascript代码的情况下实现平稳退化,支持浏览器的情况下,<noscript>标签中的内容不会显示。
JavaScript高级程序设计学习笔记第二章的更多相关文章
- JavaScript高级程序设计学习笔记第一章
		作为学习javascript的小白,为了督促自己读书,写下自己在读书时的提炼的关键点. 第一章: 1.JavaScript简史:Netscape Navigator中的JavaScript与Inter ... 
- JavaScript高级程序设计学习笔记第二十章--JSON
		1.JSON:JavaScript Object Notation, JavaScript 对象表示法. 2.最重要的是要理解它是一种数据格式,不是一种编程语言.虽然具有相同的语法形式,但 JSON ... 
- JavaScript高级程序设计学习笔记第九章--客户端检测
		1.能力检测:能力检测的目标不是识别特定的浏览器,而是识别浏览器的能力.(我的理解就是识别浏览器能做什么不能做什么) 2.怪癖检测:目标是识别浏览器的特殊行为.但与能力检测确认浏览器支持什么能力不同, ... 
- JavaScript高级程序设计 读书笔记 第二章
		<script>元素 直接在页面中嵌入JavaSript代码或包含外部JavaSript文件. 在代码中任何地方不能出现</script>,可通过转义字符'\'解决. 在XHT ... 
- 《JavaScript高级程序设计》笔记——第一章到第三章
		2019年,新年伊始,我打算好好重读一下<JavaScript高级程序设计>这本前端必备经典书.每天半小时. 以下内容摘自<JavaScript高级程序设计> 2019-2-1 ... 
- JavaScript高级程序设计---学习笔记(一)
		今天,2017.3.17开始利用课余时间仔细学习<JavaScript高级程序设计>,将需要掌握的知识点记录下来,争取把书里的所有代码敲一遍并掌握. 1.标识符命名最好是第一个字母小写,剩 ... 
- javascript高级程序设计学习笔记
		javascript高级程序设计,当枕头书已经好久了~zz 现在觉得自己在js的开发上遇到了一些瓶颈,归根究底还是基础太薄弱,所以重新刷一遍js高程希望有更新的认识. 一.javascript简介 ... 
- Javascript高级程序设计学习笔记一
		看完w3school的javascript的概念,有点基础,开始红皮书的路程,今晚总结前二章的心得. 第一章:javascript简介 重点是javascript的实现是由 ECMAScript(核心 ... 
- JavaScript高级程序设计学习笔记第三章--基本概念
		一.标识符: 1.区分大小写 2.命名规则: 第一个字符必须是一个字母.下划线(_)或一个美元符号($) 其他字符可以是字母.下划线.美元符号或数字 标识符中的字母也可以包含扩展的 ASCII 或 U ... 
随机推荐
- HDU 5374 Tetris (2015年多校比赛第7场)
			1.题目描写叙述:点击打开链接 2.解题思路:本题要求模拟俄罗斯方块游戏.然而比赛时候写了好久还是没过. 后来补题发现原来是第四步的逻辑实现写错了... 题目中要求假设一整行能够消除,那么仍然运行该步 ... 
- 错误记录--更改tomcat端口号方法,Several ports (8005, 8080, 8009)【转】
			启动Tomcat服务器报错: Several ports (8005, 8080, 8009) required by Tomcat v5.5 Server at localhost are alre ... 
- C#Panel 控件的使用
			Windows 窗体 Panel 控件用于为其他控件提供可识别的分组.通常,使用面板按功能细分窗体.例如,可能有一个订单窗体,它指定邮寄选项(如使用哪一类通营承运商).将所有选项分组在一个面板中可向用 ... 
- 九度OJ 1150:Counterfeit Dollar(假美元) (分析、检验)
			时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:485 解决:215 题目描述: Sally Jones has a dozen Voyageur silver dollars. Howev ... 
- apache功能优化
			隐藏Apache版本等敏感信息 $ grep Server /usr/local/httpd/conf/extra/httpd-default.conf|grep -v "#" 修 ... 
- iOS 流布局 UICollectionView使用(UICollectionVIew的代理方法)
			UICollectionViewDataSource协议 这个协议主要用于collectionView相关数据的处理,包含方法如下: 设置分区数(这个是可选实现的) - (NSInteger)numb ... 
- BZOJ2328: [HNOI2011]赛车游戏
			BZOJ2328: [HNOI2011]赛车游戏 Description 题解Here! 一开始被题面那一长串的描述吓到了,一直没敢做... 然后尝试着硬着头皮读懂题面. 然后...这不是贪心么??? ... 
- Oozie-1-安装、配置   让Hadoop流动起来
			版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/wl101yjx/article/details/27881739 写在前面一: 本文总结 基于Had ... 
- Linux下监视GPU、CPU的使用情况
			1.在运行Tensorflow等程序时会使用到NVIDIA的GPU,所以在程序运行时需要监控GPU的运行情况 使用 nvidia-smi 命令 ,显示如下: nvidia-smi 显示解读: GPU: ... 
- Java for LeetCode 124 Binary Tree Maximum Path Sum
			Given a binary tree, find the maximum path sum. The path may start and end at any node in the tree. ... 
