浅谈DOM和BOM

1.1,文档对象模型


文档对象模型(DOM,Document Object Model)是针对XML但是经过扩展用于HTML的应用程序编程接口(API).DOM把整个页面映射为一个多层节点结构.HTML或XML页面中的每个组成部分都是某种类型的节点,这些节点又包含着不同类型的数据,开发人员获得了控制页面内容和结构的主动权,借助DOM提供的API,开发人员可以轻松自如地删除,添加,替换或修改任何节点。

1.2,为什么要使用DOM?


由于网景和微软在开发DHTML方面各持己见,为了防止浏览器不兼容的情况出现,负责制定网络通信标准的W3C开始着手规划DOM。
DOM1级的目标主要是映射文档的结构,那么DOM2级的目标就要宽泛多了,DOM2级在原来DOM的基础上又扩充了鼠标和用户界面事件,范围,遍历等细分模块,而且通过对象接口增加了对CSS的支持.DOM1级中的DOM核心模块也经过扩展开始支持XML命名空间.DOM2级引入
了下列新模块,也给出了众多新类型和新接口的定义:
(1)DOM视图:定义了跟踪不同文档视图的接口
(2)DOM事件:定义了事件和事件处理的接口
(3)DOM样式:定义了基于CSS为元素应用样式的接口
(4)DOM遍历和范围:定义了遍历和操作文档树的接口
DOM3级则进一步扩展了DOM,引入了以统一方式加载和保存文档的方法

2.1浏览器对象模型(BOM)


开发人员使用BOM可以控制浏览器显示的页面以外的部分
从根本上讲,BOM只处理浏览器窗口和框架,人们但习惯上也。把
所有针对浏览器的JavaScript的扩展算作BOM的一部分。下面就是一些这样的扩展:
(1)弹出新浏览器窗口的功能
(2)移动,缩放和关闭浏览器窗口的功能
(3)提供浏览器详细信息的导航器对象
(4)提供浏览器所加载页面的详细信息的位置对象
(5)提供用户显示器分辨率详细信息的屏幕对象
(6)对饼干的支持
(7)像的XMLHttpRequest和IE的ActiveXObject的这样的自定义对象
BOM没有标准,所以每个浏览器都有自己的实现。(补充:虽然也存在一些事实标准,比如要有窗口对象和导航对象)
现在有了HTML5,BOM实现的细节有望朝着兼容性越来越高的方向发展

猜你喜欢

转载自blog.csdn.net/qq_39178993/article/details/81226731