摘要:先讨论JavaScript的由来和一些比较容易混淆的概念,又讨论了JavaScript的实现,紧接着说明了在网页中怎么有效地更好地引入js代码。
是从一个简单的输入验证器变成的一门强大的解释型编程语言。
JavaScript和Java关系不大。Java 和Javascript是雷锋和雷峰塔的关系。(来自佚名的《JS继承机制》的故事)
JavaScript 和JScript的关系一定程度上类似于Java和C#的关系,不同的是Javascript和JScript部分相兼容。
ECMAScript是欧洲计算机制造商协会(ECMA) 联合一些公司的程序员一起制定的脚本语言的标准。
JavaScript的实现由下列三个不同的部分组成:
(1)ECMAScript与Web浏览器没有依赖关系,本身不包含输入和输出定义。
ECMAScript的宿主环境包括Web浏览器,Node(一种服务端JavaScript平台)和Adobe Flash。
宿主环境不仅提供基本的ECMAScript实现,也提供了该语言的扩展,以便语言与环境之间进行交互。(Web浏览器提供的就是DOM)
(2)DOM是针对XML但经过扩展用于HTML的应用程序编程接口(API).
DOM把整个页面映射成一个多层节点结构。
(3)BOM提供与浏览器交互的方法和接口。
<script>元素负责引入JavaScript代码。
有两种引入方式:(不做举例,详细参考w3school里的讲解)
尽可能使用外部文件来包含JavaScript代码。 可维护性,可缓存,适应未来。。
该元素有六个属性:
只要不存在defer和async属性,在解释器对<script>元素内部的所有代码求值完毕前(包括下载外部代码文件时),
页面中的其余内容都不会被浏览器加载。
带有src属性的<script>标签之间不应该包含额外的Js代码,只会下载并执行外部脚本文件,而忽略嵌入的代码。
(1) 传统做法,所有<script>元素都应该放在<head>元素中。
意味着必须等到全部JavaScript代码都被下载、解析和执行完成后,才开始呈现页面的内容(浏览器在遇到<body>才开始呈现内容)。
问题:JS代码很多,很大。则网站体验就囧了。
解决方法,参见(2)
(2) 现代的做法,把全部JavaScript引用放在<body>元素中页面内容的后面。