获得本站免费赞助空间请点这里
返回列表 发帖

DOM的一些概念


: z7 d  v) B) g开放分类: 互连网、网页制作、web技术
" D* r4 b) n% O. IDOM是Document Object Model文档对象模型的缩写。根据W3C DOM规范(http://www.w3.org/DOM/),DOM是一种与浏览器,平台,语言无关的接口,使得你可以访问页面其他的标准组件。简单理解,DOM解决了Netscape的Javascript和Microsoft的Jscript之间的冲突,给予web设计师和开发者一个标准的方法,让他们来访问他们站点中的数据、脚本和表现层对像。# U; _# p. x" ~/ z: J
$ i/ }; M% R6 Q7 c$ U5 v' W# @! a
DOM是以层次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在树中导航寻找特定信息。分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作。由于它是基于信息层次的,因而 DOM 被认为是基于树或基于对象的。
9 O: t+ N: R% I6 H. r& t. w' D( @/ l; L( c- {6 v
对于特别大的文档,解析和加载整个文档可能很慢且很耗资源,因此使用其他手段来处理这样的数据会更好。这些基于事件的模型,比如 Simple API for XML(SAX),适用于处理数据流,即随着数据的流动而依次处理数据。基于事件的 API 消除了在内存中构造树的需要,但是却不允许开发人员实际更改原始文档中的数据。4 J# l' F, X/ l: b3 h
SAX等模型会从头至尾的顺序解析整个XML文档,当遇到一个节点的开始或或者结束时,会产生一个时间,程序员可以注册事件处理函数以对各个节点进行处理。, s1 `, T# G- l: E

6 H6 ~8 }  R' I另一方面,DOM 还提供了一个 API,允许开发人员添加、编辑、移动或删除树中任意位置的节点,从而创建一个引用程序。这个模型就是基于树型数据结构的,他在使用之前必须加载整个文档或者至少是结构良好的文档片段7 C$ }, Y: y5 ?% [$ \) b1 e$ l

2 v" o9 `% a) @7 \% Y& B2 ~# K解析器是一个软件应用程序,设计用于分析文档(这里是指 XML 文件),以及做一些特定于该信息的事情。在诸如 SAX 这样基于事件的 API 中,解析器将向某种监听器发送事件。在诸如 DOM 这样基于树的 API 中,解析器将在内存中构造一颗数据树。1 @& F* K1 u! p$ j

; U8 \/ ?9 S- b! m: N! {& O作为 API 的 DOM& d3 @( p: S& ]9 z  Q* @3 e% Q

  @3 x9 ~: H: p' g0 w8 l2 `从 DOM Level 1 开始,DOM API 包含了一些接口,用于表示可从 XML 文档中找到的所有不同类型的信息。它还包含使用这些对象所必需的方法和属性。7 |! h3 u/ P$ S8 n- U( ?  b4 D  Q

. `0 i5 w0 ]( x, W/ y- I* M4 ?Level 1 包括对 XML 1.0 和 HTML 的支持,每个 HTML 元素被表示为一个接口。它包括用于添加、编辑、移动和读取节点中包含的信息的方法,等等。然而,它没有包括对 XML 名称空间(XML Namespace)的支持,XML 名称空间提供分割文档中的信息的能力。
9 x% N) L8 e5 H5 [3 @0 c" \
/ S  |) O5 [: Z/ q! }: D: j! Y4 QDOM Level 2 添加了名称空间支持。Level 2 扩展了 Level 1,允许开发人员检测和使用可能适用于某个节点的名称空间信息。Level 2 还增加了几个新的模块,以支持级联样式表、事件和增强的树操作。
+ K. p: {- y) V4 g' s0 E. v/ c
当前正处于定稿阶段的 DOM Level 3 包括对创建 Document 对象(以前的版本将这个任务留给实现,使得创建通用应用程序很困难)的更好支持、增强的名称空间支持,以及用来处理文档加载和保存、验证以及 XPath 的新模块;XPath 是在 XSL 转换(XSL Transformation)以及其他 XML 技术中用来选择节点的手段。& x, z! b2 o" [$ D

6 A7 y4 ^. q2 S) KDOM 的模块化意味着作为开发人员,您必须知道自己希望使用的特性是否受正在使用的 DOM 实现所支持。! p% Q0 B* k5 @( E6 r

, Z6 r5 h1 u" V+ Y# j确定特性可用性
* G7 @8 V/ Y3 Y; ~9 L2 o
) B# H' M: n0 p* C$ y6 j; ?- {DOM 推荐标准的模块性质允许实现者挑选将要包括到产品中的部分,因而在使用某个特定的特性之前,首先确定该特性是否可用可能是必要的。本教程仅使用 DOM Level 2 Core API,不过在着手您自己的项目时,了解如何能够检测特性是有所帮助的。
* Q4 ?5 v1 @+ ?& U! r
$ f' [' e* E: `* b) z. R% eDOM 中定义的接口之一就是 DOMImplementation。通过使用 hasFeature() 方法,您可以确定某个特定的特性是否受支持。DOM Level 2 中不存在创建DOMImplementation 的标准方法,不过下面的代码将展示如何使用 hasFeature() 来确定 DOM Level 2 样式表模块在某个 Java 应用程序中是否受支持。4 ~  f( a1 j' `4 B( M9 v, L) e

9 I+ s3 z$ p' k% ^8 ximport javax.xml.parsers.DocumentBuilderFactory;! |# L3 C( c6 }; s% H; O

4 Z5 M3 j& O+ n/ Z; u7 Kimport javax.xml.parsers.DocumentBuilder;
- D$ _* D( J  s5 F! D5 c# f: x/ [6 s2 T4 r- q; n
import org.w3c.dom.DOMImplementation;
7 q4 H  w& M# p1 x! X9 Q& k. A
public class ShowDomImpl {
. w9 E, [$ U5 u$ J; ^# ?8 a- u$ G2 u' E
public static void main (String args[]) {
$ o7 I) n* F- f# T
3 |9 R: D& I' Ytry {
4 b9 f2 n: P+ u% P- q
9 |0 s: H) [& L* U$ SDocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
+ e; u: s/ {" g# @. E' _. G7 I" ?; z- N- p/ @9 W( a: n
DocumentBuilder docb = dbf.newDocumentBuilder();
/ v# w$ }, }# F
. k2 \9 H, q9 l7 wDOMImplementation domImpl = docb.getDOMImplementation();$ \! J/ L1 a2 v0 {2 d, h: C

2 u- i+ N: C) X7 H/ G$ R; D, `if (domImpl.hasFeature("StyleSheets", "2.0")) {
9 p& I6 }8 a1 I2 z3 o. Z* ]) m& ^# Y7 L7 l" c* g  x- a. P! @
System.out.println("Style Sheets are supported.");; i6 |5 T3 V9 B. b; x  i/ R
2 t' K! h+ p3 ~5 t8 M5 s# E- o
} else {1 Q6 `% V" f7 H& ^

6 l" \& r( }! A  N0 YSystem.out.println("Style Sheets are not supported.");% A! w: J( ]; O' o& B7 ]

  P3 N/ i* w+ o" n% F; ?/ w}
1 h6 M! I) |! h2 d& x, p' L
3 f  D$ m7 d5 H' f! w# M, x$ [* E! D2 `} catch (Exception e) {}
9 [9 s" i% [& l- s( ~! {0 t' S2 q, E( U# k2 K
}
/ L( u; U0 V8 I, i/ d$ f, }4 B1 d, P7 C( z0 P
}
7 ?' N1 w4 e% y) [( h/ `0 J: b
  Y. B7 ^% u( I5 s( J(DOM Level 3 将包括用于创建 DOMImplementation 的标准方法。)
7 c/ k% @1 Y2 w8 I: ~- l/ [
$ V; j$ N/ \9 R% ~, v% O; t本教程将使用单个文档来展示 DOM Level 2 Core API 的对象和方法。9 V0 g5 R+ y9 x. @$ ~

' V6 o7 {9 p6 `$ Q3 U  U( ~基本的 XML 文件
7 P; D: P, V0 m$ A# J" @+ B# M9 a- Y0 ?
本教程中的所有例子都是用了一个包含如下节点的 XML 文件,它表示输入某个商业系统的订单。回顾一下,XML 文件的基本组成部分包括:
' I$ U: d, F2 C4 }: C5 ^
- P( L' Z- m- A7 HXML 声明:基本的声明 <?xml version="1.0" encoding="UTF-8"?> 将这个文件定义为 XML 文档。在声明中指定一种字符编码的情况并不鲜见,如下所示。通过这种方式,不管该 XML 文件使用的语言或字符编码是什么,只要解析器理解特定的编码,它就能够正确地读取该 XML 文件。
7 `1 D/ }3 @' j, t" i6 [& E0 d" I. }2 B5 w5 a
DOCTYPE 声明:XML 是人机之间交换信息的便利手段,但是要使它能够顺利地工作,必须要有一个公共的词汇表。可选的 DOCTYPE 声明可用于指定一个应该用来与此文件做比较的文档(在本例中为 orders.dtd),以确保不会产生任何混淆或丢失信息(例如,丢失一个 userid 或错误拼写某个元素名称)。以这种方式处理过的文档称为有效的文档。成功的有效性检查并不是 XML 所必需的,后面的例子实际上从文档中省略了 DOCTYPE 声明。
* Z9 R7 c" P9 a# ^% M# r3 L5 G- A
数据本身:XML 文档中的数据必须包含在单个根元素内,比如下面的 orders 元素。要使 XML 文档得到处理,它必须是格式良好的(well-formed)。  Q2 l/ m) j+ a
5 D5 r! A) \- I# _; s# ^
<?xml version="1.0" encoding="UTF-8"?>
) C% l! Y+ L/ @$ v4 b* v* _0 {4 j! |' d+ ?" ]1 z
<!DOCTYPE ORDERS SYSTEM "orders.dtd">: H3 x0 \( t# y  B3 w% b" {
7 G0 P/ E+ x, z3 f
<orders>
2 b* |6 B; P0 l9 i3 p
6 z, o' W$ F7 k$ ~1 r+ L   <order>, w7 c7 p- \5 K  x. u4 c

3 {- q/ \* b" _8 f3 Z       <customerid limit="1000">12341</customerid>
+ O: A. w' B# ?
& T6 P, c* v% t5 ]       <status>pending</status>
0 P9 `9 n' T. n1 @1 ~) e  c" d4 l1 M+ y
       <item instock="Y" itemid="SA15">, `/ r- z; S; B

1 \3 w+ D: {9 m& l6 e          <name>Silver Show Saddle, 16 inch</name>- |) c& b: B0 u8 t& `7 u

& Z) o* Q, V7 F# f+ i: f          <price>825.00</price>1 P& q4 S% u& N& ]/ T$ }

; @: ?3 W; T  T6 l- a          <qty>1</qty>1 ]/ [, _' u/ z2 V! z) K7 I
* `4 p' D$ K3 G( H6 u
       </item>
& Q' q, n- K5 j# r; v# R1 Z$ x' r! K: v; J
       <item instock="N" itemid="C49">
1 e+ T" Q% n7 ^2 D& J; `* e% K' r! y3 m- p: m$ P0 p' s
         <name>;Premium Cinch</name>
: j% \: |& q' J& D' r+ E+ W1 W% r+ Y9 C3 t* ?% y$ s6 ]. a& A; M3 S% H
         <price>49.00</price>
$ j& R' A, y% l! d
( d) ?& N: N2 {$ V. S$ e3 `         <qty>1</qty>
3 o4 \9 n+ ?' W( F& A# O/ Y
: u* Z- \. ^9 ?! q) i. V' Z       </item>1 e7 [2 a/ E6 x

8 ?/ u! @  Y4 k3 \( H0 p9 I$ |/ A0 K  </order>
3 W6 o: a( j$ g- z+ a  C0 X* x& x$ h3 j6 E4 w
<order>
0 e2 U/ h, \3 K0 ?/ P: r# |+ C' C" q- X
   <customerid limit="150">251222</customerid>. s2 J1 n# N+ U$ k+ X2 _

5 f6 b* Z7 a3 E2 e1 b' Z9 ~4 f   <status>pending</status>9 @$ L% T2 P# F8 W2 [

$ p! i& N, k8 m1 Z! ^   <item instock="Y" itemid="WB78">
7 c, x+ R1 N. d  C' m/ V( q  a4 x/ R3 _
     <name>Winter Blanket (78 inch)</name>
; J, |, c. Q; c
; ]2 I7 G" t+ y$ `$ L9 y     <price>20</price>7 i9 }( S# n' n& Q9 j4 X
% ?4 c% i: A7 Y
     <qty>10</qty>2 \: G2 E& R* w0 n
1 @. T: l$ k' n4 V! ?( e
   </item>
/ d8 |6 s+ j. S# \
9 M7 Y0 V# b! o3 x</order>4 Q  F9 I7 k# m% h, \7 P7 m

2 {' d6 U8 ^, d) e; w0 q. V</orders>
8 s$ x  S7 {( h7 S/ r8 H在 DOM 中,使用 XML 信息意味着首先将它划分为节点。

返回列表
【捌玖网络】已经运行: