一个完整的 JavaScript实现应该由下列三个不同的部分组成:
#核心(ECMAScript)
#文档对象模型(DOM)
#浏览器对象模型(BOM)
1、ECMAScript
提供核心语言功能
它规定了这么语言的下列组成部分:
1.1、语法
1.2、类型
1.3、语句
1.4、关键字
1.5、保留字
1.6、操作符
1.7、对象
2、DOM
提供访问和操作网页内容的方法和接口。
文档对象模型式针对XML但经过扩展用于HTML的应用程序编程接口。DOM把整个页面映射为一个多层节点结构。HTML或XML页面中的每个组成部分都是某种类型的节点,这些节点又包含着不同类型的数据。
DOM级别:DOM1、DOM2、DOM3
DOM1
由两个模块组成:DOM核心(DOM Core)和DOM HTML.
DOM核心规定的是如何映射基于XML的文档结构,以便简化对文档中任意部分的访问和操作。DOM HTML模块则在DOM核心的基础上加以扩展,增加了针对HTML的对象和方法。
注意:DOM并不只是针对JavaScript的,很多别的语言也都实现了DOM.
DOM2
DOM2级在原来DOM的基础上又扩充了(DHTML一致都支持的)鼠标和用户界面事件、范围、遍历(迭代DOM文档的方法)等细分模块,而且通过对象接口实现了对CSS(Cascading Style Sheets,层叠样式表)的支持。DOM1级中的DOM核心模块也经过扩展开始支持XML命名空间。
DOM2级引入了下列新模块,也给出了众多新类型和新接口的定义:
#DOM视图(DOM Views):定义了跟踪不同文档视图的接口。
#DOM事件(DOM Events):定义了事件和事件处理的接口。
#DOM样式(DOM Style):定义了基于CSS为元素应用样式的接口。
#DOM遍历和范围(DOM Traversal and Range):定义了遍历和操作文档树的接口。
DOM3
DOM3进一步扩展了DOM:
#引入了以统一方式加载和保存文档的方法——在DOM加载和保存(DOM Load and Save)模块中定义;
#新增了验证文档的方法——在DOM验证(DOM Validation)模块中定义。
#新增了验证文档的方法——在DOM验证(DOM Validation)模块中定义。
#对DOM核心进行了扩展,开始支持XML 1.0,涉及XML Infoset、XPath和XML Base。
3、BOM
提供与浏览器交互的方法和接口。
在HTML5之前,BOM真正与众不同的地方(也是经常会导致问题的地方),还是它作为JavaScript实现的一部分但却没有相关的标准。这个问题再HTML5中得到了解决,HTML5致力于把很多BOM功能写入正式规范。
从根本上将,BOM只处理浏览器窗口和框架;但人们习惯上也把所有针对浏览器的JavaScript扩展算作BOM的一部分。下面就是一些这样的扩展:
#弹出新浏览器窗口的功能;
#移动、缩放和关闭浏览器窗口的功能;
#提供浏览器详细信息的navigator对象;
#提供浏览器所加载页面的详细信息的location对象;
#提供用户显示器分辨率详细信息的scree对象;
#对cookies的支持
#像XMLHttpRequest和IE的ActiveXObject这样的自定义对象。