|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14389
- 金币
- 2480
- 威望
- 1647
- 贡献
- 1428
|
" B m7 d1 ~: y: ~
开放分类: 互连网、网页制作、web技术2 U9 V* ~+ ]6 W ]% I
DOM是Document Object Model文档对象模型的缩写。根据W3C DOM规范(http://www.w3.org/DOM/),DOM是一种与浏览器,平台,语言无关的接口,使得你可以访问页面其他的标准组件。简单理解,DOM解决了Netscape的Javascript和Microsoft的Jscript之间的冲突,给予web设计师和开发者一个标准的方法,让他们来访问他们站点中的数据、脚本和表现层对像。, C# s. b4 O7 w3 O R% D9 k
9 d+ C) o0 c$ ]
DOM是以层次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在树中导航寻找特定信息。分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作。由于它是基于信息层次的,因而 DOM 被认为是基于树或基于对象的。' |8 A8 w+ e* @
& Q6 a5 h2 A7 R对于特别大的文档,解析和加载整个文档可能很慢且很耗资源,因此使用其他手段来处理这样的数据会更好。这些基于事件的模型,比如 Simple API for XML(SAX),适用于处理数据流,即随着数据的流动而依次处理数据。基于事件的 API 消除了在内存中构造树的需要,但是却不允许开发人员实际更改原始文档中的数据。* ^% p; G2 _, ]7 _' q+ [0 n
SAX等模型会从头至尾的顺序解析整个XML文档,当遇到一个节点的开始或或者结束时,会产生一个时间,程序员可以注册事件处理函数以对各个节点进行处理。
7 R0 P4 z+ {# @' F7 V
, Y7 z" t+ f) R另一方面,DOM 还提供了一个 API,允许开发人员添加、编辑、移动或删除树中任意位置的节点,从而创建一个引用程序。这个模型就是基于树型数据结构的,他在使用之前必须加载整个文档或者至少是结构良好的文档片段4 K1 W6 q# x* t0 V% A- t1 d
# s* `" p3 Z) q/ q9 p0 F: r$ V* V1 X解析器是一个软件应用程序,设计用于分析文档(这里是指 XML 文件),以及做一些特定于该信息的事情。在诸如 SAX 这样基于事件的 API 中,解析器将向某种监听器发送事件。在诸如 DOM 这样基于树的 API 中,解析器将在内存中构造一颗数据树。5 T" T( d( @! t/ g' v
* z4 [3 N# u( H1 T$ ^# ?作为 API 的 DOM# M4 v4 y: {/ J- q% F; c
7 ?: P" M! a2 S
从 DOM Level 1 开始,DOM API 包含了一些接口,用于表示可从 XML 文档中找到的所有不同类型的信息。它还包含使用这些对象所必需的方法和属性。
& w Q- k/ |% R# M7 N: r- h% W5 Z. I# l- v2 j9 i f1 H
Level 1 包括对 XML 1.0 和 HTML 的支持,每个 HTML 元素被表示为一个接口。它包括用于添加、编辑、移动和读取节点中包含的信息的方法,等等。然而,它没有包括对 XML 名称空间(XML Namespace)的支持,XML 名称空间提供分割文档中的信息的能力。
7 O& J, {2 T5 x4 P5 Q/ v: E7 D( g, a2 K
DOM Level 2 添加了名称空间支持。Level 2 扩展了 Level 1,允许开发人员检测和使用可能适用于某个节点的名称空间信息。Level 2 还增加了几个新的模块,以支持级联样式表、事件和增强的树操作。+ _! W& H3 L, s7 y* H
! @) w( P, p d& n0 h2 p
当前正处于定稿阶段的 DOM Level 3 包括对创建 Document 对象(以前的版本将这个任务留给实现,使得创建通用应用程序很困难)的更好支持、增强的名称空间支持,以及用来处理文档加载和保存、验证以及 XPath 的新模块;XPath 是在 XSL 转换(XSL Transformation)以及其他 XML 技术中用来选择节点的手段。, n" W2 K" t1 p+ V
1 y5 \! H8 P G. Q. Q$ {DOM 的模块化意味着作为开发人员,您必须知道自己希望使用的特性是否受正在使用的 DOM 实现所支持。6 E* n) I* H+ \- c
$ m2 b8 }& D: f0 y# k6 o确定特性可用性
9 d6 U* ~: O+ I! r% O4 {
' s) A8 a: ]: }6 |0 t- e1 uDOM 推荐标准的模块性质允许实现者挑选将要包括到产品中的部分,因而在使用某个特定的特性之前,首先确定该特性是否可用可能是必要的。本教程仅使用 DOM Level 2 Core API,不过在着手您自己的项目时,了解如何能够检测特性是有所帮助的。3 j( W4 D0 d9 Y0 [- F' ~1 \! r+ S& d
- Q% o7 P3 ~! S2 X1 A4 iDOM 中定义的接口之一就是 DOMImplementation。通过使用 hasFeature() 方法,您可以确定某个特定的特性是否受支持。DOM Level 2 中不存在创建DOMImplementation 的标准方法,不过下面的代码将展示如何使用 hasFeature() 来确定 DOM Level 2 样式表模块在某个 Java 应用程序中是否受支持。
* g A7 ?) ?7 Q3 [ a1 m! y* T* p7 n# T9 o. u& m) I* X4 Y
import javax.xml.parsers.DocumentBuilderFactory;
" J# j/ @# U9 G2 `
2 Y: }. r- x% x- `import javax.xml.parsers.DocumentBuilder;9 p, R* G. h/ S$ ~
/ a* ~8 F# @6 j; t7 D W
import org.w3c.dom.DOMImplementation;. l/ y0 u3 Z* o' f& p8 R
# j! A$ P+ J# H' S" [public class ShowDomImpl {, C S+ k2 K" t+ t
! ]2 k) w4 Z9 y: lpublic static void main (String args[]) {
% L) f* y9 R2 H3 j: D( R; H% Z" U: ]+ u6 I: I J0 j
try {
7 O4 D0 C5 ^" k' `9 z- m, j. j4 L3 e \: t
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
& q3 f1 i& ^/ o6 K: }' H$ J
+ K. H- u: i, Z7 Z# hDocumentBuilder docb = dbf.newDocumentBuilder();
# C' b, ? W9 }- I: @* Q8 ]" l2 w
DOMImplementation domImpl = docb.getDOMImplementation();
/ Q( Z/ Q' G& E, `# H, ]3 S# S4 N; e; _6 ~! W, S. D/ V% z' y
if (domImpl.hasFeature("StyleSheets", "2.0")) { E2 e# K$ f/ K# w
, m& M- F1 G6 `0 H. x6 SSystem.out.println("Style Sheets are supported.");
9 Q; @. B j1 U' O& W, {7 S" o5 I/ l: z/ A! q* ], u* J! a- J! O, o' K
} else {+ ?) M* Z+ y1 c7 e- F
- m/ _& `( O/ L" F1 _1 _
System.out.println("Style Sheets are not supported.");" Q/ D- d& `1 K9 }
8 r4 _0 ], s3 ~! a1 N
}( a C, }% H' F- O4 p
) |+ ~0 F/ {6 \+ A: U} catch (Exception e) {}0 _" [9 R4 x6 T4 V$ e, j7 L6 P) C
3 J7 t! E# q' t8 c1 ?0 ?) w) L}% N& e. u3 d& X5 U9 A! y
; A5 u9 m A' m) ?! R1 D}% }) \; }( z, s/ V+ C8 U1 Q
# K3 y5 l' _/ Y, j/ P2 |
(DOM Level 3 将包括用于创建 DOMImplementation 的标准方法。)/ m0 A# x7 b J& k/ H+ G
: W8 l/ U0 [6 ~& F8 P
本教程将使用单个文档来展示 DOM Level 2 Core API 的对象和方法。* t* g0 { S/ A8 Y* b1 h
( \% J! a+ k6 s9 f3 x1 [% h5 [基本的 XML 文件% O7 O, T: ~/ V9 A0 n
2 ]( z( t& {6 Y$ W本教程中的所有例子都是用了一个包含如下节点的 XML 文件,它表示输入某个商业系统的订单。回顾一下,XML 文件的基本组成部分包括:
. X0 \ S1 U- r! O0 R! A
1 _7 q/ ^2 k. v4 ~0 v5 B4 mXML 声明:基本的声明 <?xml version="1.0" encoding="UTF-8"?> 将这个文件定义为 XML 文档。在声明中指定一种字符编码的情况并不鲜见,如下所示。通过这种方式,不管该 XML 文件使用的语言或字符编码是什么,只要解析器理解特定的编码,它就能够正确地读取该 XML 文件。
1 c P) y( F7 D" i; T" `/ p+ r& a* i0 m2 p
DOCTYPE 声明:XML 是人机之间交换信息的便利手段,但是要使它能够顺利地工作,必须要有一个公共的词汇表。可选的 DOCTYPE 声明可用于指定一个应该用来与此文件做比较的文档(在本例中为 orders.dtd),以确保不会产生任何混淆或丢失信息(例如,丢失一个 userid 或错误拼写某个元素名称)。以这种方式处理过的文档称为有效的文档。成功的有效性检查并不是 XML 所必需的,后面的例子实际上从文档中省略了 DOCTYPE 声明。" k' ^) @4 \5 c9 y; n
& H j' g+ Y2 V: b+ r% P* d% D+ R数据本身:XML 文档中的数据必须包含在单个根元素内,比如下面的 orders 元素。要使 XML 文档得到处理,它必须是格式良好的(well-formed)。+ p' @) L3 f$ b( v3 a+ r% b3 |
' M2 H/ E3 W& \/ e0 h$ ?# @7 {+ C<?xml version="1.0" encoding="UTF-8"?>
+ t( J- j1 e; S9 c5 {( s. G+ H8 _/ w0 _2 t2 }& ?2 o
<!DOCTYPE ORDERS SYSTEM "orders.dtd">
+ e/ T9 Q6 Y0 @1 J) r8 v: \4 r% s9 z9 C! h& h# x
<orders>) ]; E$ x2 `( M0 g, O9 R$ P
. a% u7 g+ n+ K
<order>
3 G% i7 S! i; M9 h" ^2 }. ?6 g1 u* m& d0 q( K
<customerid limit="1000">12341</customerid>4 J5 A1 a6 w0 S5 c# G
9 v+ a0 V+ {4 B, n% z
<status>pending</status>
9 J c1 y1 p8 c# k$ a" L0 _
! V1 t4 f0 A& [( P9 x <item instock="Y" itemid="SA15">
# R7 i3 h/ }2 s/ l8 R6 ?( r# I! r+ H* `- ]
<name>Silver Show Saddle, 16 inch</name>4 E( a7 W; B4 ?7 F5 u
' m$ w* P: g0 C
<price>825.00</price>
0 S4 I" x4 }% j$ n: v( e% y& c# K6 N- {& v+ u' }
<qty>1</qty>
6 G6 F0 k: J: n) _, I, V! G! F) @9 c( a% D8 n3 h% S- B% Q
</item>
$ M9 M, F; t' g# Y7 q0 r; E1 \7 y0 d: I0 ~1 z
<item instock="N" itemid="C49">9 Q' O2 F/ G* ?) y; c2 `! T
6 B A9 q! {# q" G6 J1 W' l/ I1 ? <name>;Premium Cinch</name>
% u# Q7 g! o; \: O5 `" \/ _" u1 C' N) K: s8 |; }7 N1 W" B
<price>49.00</price>- d: p5 t, e6 |; M" o% l% g
! P1 R1 X; f! [ <qty>1</qty># y. J* w5 R7 _1 s c
* w9 [. ?$ l+ v) q </item>
1 X8 ~6 h% m$ o) O$ O
1 b1 b0 R$ \+ s- R( k </order>
9 i6 y( k/ u- s) ]4 Q# s5 q; X0 T1 k% f+ l
<order>
- S2 r& p: S) W1 J: M1 P) x7 T" m2 Y1 Q% E/ y
<customerid limit="150">251222</customerid>, C5 a2 W( ]# X
6 q7 C5 c, l3 {2 `! a, s( Z# \ <status>pending</status># {/ {. {7 O8 p+ k7 ]) |
9 R6 T; m: e" ^( P% b <item instock="Y" itemid="WB78">
" l5 x @ P- _& p ~2 r! T, |& ~ U
1 i5 r f7 g9 C+ A <name>Winter Blanket (78 inch)</name>
4 }' G' Z0 ~3 v& M: f9 S c, k5 }5 n0 l3 Z6 z
<price>20</price>
% e7 J$ L* R+ f- {
& a1 Q7 _% N0 `% P! p" d <qty>10</qty> p3 Z. ]# _# h7 Q4 Y
+ ?. C- F; S" x </item>
2 J# B+ Q8 y, A2 K' M1 B5 S, H/ g: r0 I4 @ z& U- o
</order>/ n. L8 |* E8 j5 X1 c" g
8 I4 ]* J) C5 |) R( t! Z: i/ N</orders>
. ]& e' c2 O( m在 DOM 中,使用 XML 信息意味着首先将它划分为节点。 |
|