龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > web编程 > Javascript编程 >

HTML DOM与XML DOM的区别与联系探究(1)

时间:2013-03-06 14:58来源:未知 作者:admin 点击:
分享到:
这里向大家描述一下HTML DOM与XML DOM的区别与联系,本文内容的主题便是,为什么开发者要认为DOM Level1规范的架构是至关重要的,其突出的重要性在哪里等等,以及还有HTMLDOM和XML DOM之间

这里向大家描述一下HTML DOM与XML DOM的区别与联系,本文内容的主题便是,为什么开发者要认为“DOM Level1规范的架构”是至关重要的,其突出的重要性在哪里等等,以及还有HTMLDOM和XML DOM之间微妙的区别及内在的联系。

大话HTML DOM与XML DOM的区别与联系

 W3C所制订的DOM Level分为两大模块:Core和HTML。第一个大模块是Core核心,W3C规范是这样描述Core的:满足软件开发者和Web脚本编写者,访问和操控产品项目中包含的可解析的HTML和XML内容。

第二个HTML模块,规范描述为:HTML之中特定元素的功能,和恰到好处的、易用的、针对常见性任务的HTML文档操作机制。

以上可见两者的重要性。同时HTML模块的意义也在于,解决了向后兼容的问题,这在当今符合DOM Level1的浏览器中已经可以提供适应的解决方案。

按照这样的说法,如果您仍然不能理解上述的要义,我们则可以这样认为,HTML文档可以使用CoreAPI和HTMLAPI两者;而XML文档只能使用CoreAPI。换句话说,HTML与XML重叠的部分有CoreAPI,而HTMLAPI则是不能共享的部分,顾名思义限于HTML文档所使用。这是我们认识Core/HTML的初步认识。

理解DOM Level1 Core

理解DOM Level1Core之要义实质在于将Core看待成为许多节点(Nodes)而组成的文档(Document),也就是说,此文档结构中可允许存在着大量的条目项,其每一项都可理解为“节点”。讨论该结构可以以两个方面入手:一、一切皆是节点对象(NodeObject,扁平化的角度去理解,flattenedview,乃适合于多态下的接口);二、每个对象继承于基类节点,实现了节点的接口(interface,OO继承的角度去理解)。请观察一下这段HTML:

  1. viewplaincopytoclipboardprint?  
  2. <dividdivid="myDiv"> 
  3. HelloWorld</div> 
  4. <dividdivid="myDiv">HelloWorld</div> 

这是一个闭合的div标签。从DOM Level1的层面来分析可以有以下几点内容:

◆标签div可作为“节点对象NodeObject(扁平化角度,前面已述)”,或者元素对象ElementOBject(继承的角度-元素继承于Node)。

◆节点属性id也可作为“节点对象NodeObject(扁平化角度)”,或者属性对象Attr.OBject(继承的角度-Attr继承于Node)。

◆文本“Helloworld”也可作为“节点对象NodeObject(扁平化角度)”,字符串对象CharacterData对象(继承的角度-CharacterData继承于Node),Text文本对象(继承的角度-Text继承于CharacterData)。

稍微归纳一下,就是DOM1Core部分中一切皆是节点,节点以及其接口都可实现在每个对象身上(从继承的角度理解出发),实现了节点接口才可以有节点的属性、方法。——这是我们理解的前提。然后,根据特定的节点类型的不同,其接口的属性和方法都是不同的,视乎DOM对该节点的设计而定。

精彩图集

赞助商链接