Board logo

标题: DOM的一些概念 [打印本页]

作者: admin    时间: 2008-7-10 15:40     标题: DOM的一些概念

4 B& b5 m/ a# |( K! }" }  B/ u5 s
开放分类: 互连网、网页制作、web技术
2 d2 ?2 }7 L' X8 N, @  L" @DOM是Document Object Model文档对象模型的缩写。根据W3C DOM规范(http://www.w3.org/DOM/),DOM是一种与浏览器,平台,语言无关的接口,使得你可以访问页面其他的标准组件。简单理解,DOM解决了Netscape的Javascript和Microsoft的Jscript之间的冲突,给予web设计师和开发者一个标准的方法,让他们来访问他们站点中的数据、脚本和表现层对像。; {% W( M2 y& @/ \/ W5 |

6 h/ `  f9 f- JDOM是以层次结构组织的节点或信息片断的集合。这个层次结构允许开发人员在树中导航寻找特定信息。分析该结构通常需要加载整个文档和构造层次结构,然后才能做任何工作。由于它是基于信息层次的,因而 DOM 被认为是基于树或基于对象的。
: P) S' n0 F$ X' p7 i  X8 k8 f/ t! Q. ]8 a
对于特别大的文档,解析和加载整个文档可能很慢且很耗资源,因此使用其他手段来处理这样的数据会更好。这些基于事件的模型,比如 Simple API for XML(SAX),适用于处理数据流,即随着数据的流动而依次处理数据。基于事件的 API 消除了在内存中构造树的需要,但是却不允许开发人员实际更改原始文档中的数据。
2 Q  W/ t$ A' |) KSAX等模型会从头至尾的顺序解析整个XML文档,当遇到一个节点的开始或或者结束时,会产生一个时间,程序员可以注册事件处理函数以对各个节点进行处理。
9 C; \" z8 ~. W: m! e- Y$ Q$ Q) h9 W- z; |# G9 p
另一方面,DOM 还提供了一个 API,允许开发人员添加、编辑、移动或删除树中任意位置的节点,从而创建一个引用程序。这个模型就是基于树型数据结构的,他在使用之前必须加载整个文档或者至少是结构良好的文档片段+ l- v$ [1 i7 Q3 e% A

% H! [" P2 W1 c7 q解析器是一个软件应用程序,设计用于分析文档(这里是指 XML 文件),以及做一些特定于该信息的事情。在诸如 SAX 这样基于事件的 API 中,解析器将向某种监听器发送事件。在诸如 DOM 这样基于树的 API 中,解析器将在内存中构造一颗数据树。* t, f8 U  C3 [" z6 X) K5 j( S
5 B" V9 s0 {) X; Q! g' x2 H/ V# b  `
作为 API 的 DOM
$ g5 z0 D3 i6 `6 ~# D( c
% q! O7 d1 t, S' G7 I5 R! _从 DOM Level 1 开始,DOM API 包含了一些接口,用于表示可从 XML 文档中找到的所有不同类型的信息。它还包含使用这些对象所必需的方法和属性。
  v9 x' B% N5 P5 G. \6 L* R
2 j  d8 T. R9 `7 u; i" j8 W) @) pLevel 1 包括对 XML 1.0 和 HTML 的支持,每个 HTML 元素被表示为一个接口。它包括用于添加、编辑、移动和读取节点中包含的信息的方法,等等。然而,它没有包括对 XML 名称空间(XML Namespace)的支持,XML 名称空间提供分割文档中的信息的能力。
5 B4 v. i& v' v* Y3 T4 m: y3 ~
8 R7 [, ~0 t5 B( A, TDOM Level 2 添加了名称空间支持。Level 2 扩展了 Level 1,允许开发人员检测和使用可能适用于某个节点的名称空间信息。Level 2 还增加了几个新的模块,以支持级联样式表、事件和增强的树操作。
3 J: x# c0 ]- j& F% M6 c) W; a/ A
当前正处于定稿阶段的 DOM Level 3 包括对创建 Document 对象(以前的版本将这个任务留给实现,使得创建通用应用程序很困难)的更好支持、增强的名称空间支持,以及用来处理文档加载和保存、验证以及 XPath 的新模块;XPath 是在 XSL 转换(XSL Transformation)以及其他 XML 技术中用来选择节点的手段。5 V+ ?4 u4 `# H# E- a0 x
4 Y$ D: e7 ^% a$ t% S7 d$ m0 {
DOM 的模块化意味着作为开发人员,您必须知道自己希望使用的特性是否受正在使用的 DOM 实现所支持。. c7 Y2 Y9 K, y% q& S4 s& t
) I# B$ ~- ]* s% J; D! n! o" R2 X
确定特性可用性
  X+ a8 e* N5 L2 F( q$ L: i7 B  s# H# G& m9 L( b% z
DOM 推荐标准的模块性质允许实现者挑选将要包括到产品中的部分,因而在使用某个特定的特性之前,首先确定该特性是否可用可能是必要的。本教程仅使用 DOM Level 2 Core API,不过在着手您自己的项目时,了解如何能够检测特性是有所帮助的。2 X, N/ J0 ]+ a4 O

' G9 R/ J" U9 m# N7 DDOM 中定义的接口之一就是 DOMImplementation。通过使用 hasFeature() 方法,您可以确定某个特定的特性是否受支持。DOM Level 2 中不存在创建DOMImplementation 的标准方法,不过下面的代码将展示如何使用 hasFeature() 来确定 DOM Level 2 样式表模块在某个 Java 应用程序中是否受支持。; \! i, J) O$ |" }  v

" l5 t( M" P1 T" Timport javax.xml.parsers.DocumentBuilderFactory;
( M1 k, k6 O2 A/ F5 l" m! \. m+ ~( y" [# y) U
import javax.xml.parsers.DocumentBuilder;9 K& ^5 y9 K4 N# n5 U/ Q9 H" o

8 i6 z. |( R# U* F" y, f* d/ Timport org.w3c.dom.DOMImplementation;5 L( m2 ^; g4 T1 {

- X) f1 D; ~! c9 k( m. G* g" Lpublic class ShowDomImpl {" x# ~+ N# W8 E( y, r) o" F5 f& }

& l/ I! B  D- V% W' Xpublic static void main (String args[]) {
$ C# c; D: Z% n8 K. G5 E, g
5 ]. O) o$ i1 {) T/ `try {
3 L1 {0 H8 F& o" ~/ F
1 V- j/ Y# x( T2 TDocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
; Y3 p- d0 Q" _+ T* w( Q8 [  Q) X; {* c6 e1 ]
DocumentBuilder docb = dbf.newDocumentBuilder();
$ ]/ G4 H$ Q4 U: {8 Y/ @2 Z1 J
7 d' Q2 f( a: C( zDOMImplementation domImpl = docb.getDOMImplementation();
1 F* h5 F/ k' b9 N1 e+ b
6 r0 ]+ U! j! {2 j5 Sif (domImpl.hasFeature("StyleSheets", "2.0")) {
( J8 p: ]7 i% M8 B$ e2 N2 F2 U2 M# j% Z% M& A' {: K! N  ~
System.out.println("Style Sheets are supported.");
" O: Y/ U3 N/ y5 Q1 ]7 I+ x, l8 Z/ j
3 t9 Y% b$ T" Q' \* o  p: u} else {1 i! r$ ]2 Y' Z4 o! c1 T3 M9 ]

7 \3 I% S9 o) ~3 L0 {, i2 xSystem.out.println("Style Sheets are not supported.");
! h- z7 |7 |& @
! L4 r0 Z- K5 ]6 I}
& e* c, {7 a. O. y* F; G
- L, Z# |) ~2 o$ N4 U} catch (Exception e) {}9 |& V6 }! r' D( g

# `7 M3 v+ T  a5 Y( z0 H}
. `, h6 N5 f: B+ z5 \. |6 P+ v  x; c3 n  ]% }9 c
}8 X3 I) \  x( a
! A! G7 J! ?7 n( a
(DOM Level 3 将包括用于创建 DOMImplementation 的标准方法。)
5 ?' u9 w2 E9 A, H
* t' C* Y# n+ C4 l# T1 }3 ]本教程将使用单个文档来展示 DOM Level 2 Core API 的对象和方法。
! k7 D, c% l9 |
: ~) [: x" ^3 k基本的 XML 文件, q: ~1 ]4 t  h2 N9 G

9 ?0 ]/ z7 u4 Z: K0 }- x* M本教程中的所有例子都是用了一个包含如下节点的 XML 文件,它表示输入某个商业系统的订单。回顾一下,XML 文件的基本组成部分包括:
/ f' s+ f+ w( Y0 S
; w0 L& n" Q. O& V; W: lXML 声明:基本的声明 <?xml version="1.0" encoding="UTF-8"?> 将这个文件定义为 XML 文档。在声明中指定一种字符编码的情况并不鲜见,如下所示。通过这种方式,不管该 XML 文件使用的语言或字符编码是什么,只要解析器理解特定的编码,它就能够正确地读取该 XML 文件。% O% R* A* V# Y7 _. t% y1 g

- R% O$ @5 x, k8 L% I: Z  U- JDOCTYPE 声明:XML 是人机之间交换信息的便利手段,但是要使它能够顺利地工作,必须要有一个公共的词汇表。可选的 DOCTYPE 声明可用于指定一个应该用来与此文件做比较的文档(在本例中为 orders.dtd),以确保不会产生任何混淆或丢失信息(例如,丢失一个 userid 或错误拼写某个元素名称)。以这种方式处理过的文档称为有效的文档。成功的有效性检查并不是 XML 所必需的,后面的例子实际上从文档中省略了 DOCTYPE 声明。! c4 W! N& j3 k8 B; M& I/ V4 j
, `8 I/ D2 ?0 f
数据本身:XML 文档中的数据必须包含在单个根元素内,比如下面的 orders 元素。要使 XML 文档得到处理,它必须是格式良好的(well-formed)。
9 O% x" }/ c# N1 O3 t! d; g+ p1 d  {7 Y6 _
<?xml version="1.0" encoding="UTF-8"?>
# K, L' j0 D# z' G6 f7 w- Q- j1 f: h. r6 Q
<!DOCTYPE ORDERS SYSTEM "orders.dtd">& b; E' e! O8 a3 B

# N) I" N* m; W. `. f<orders>. t: i  s" A& ~  D
  N* A0 c  f' I( S2 V% Z
   <order>
, m3 C9 q2 y4 l. U9 Z$ X: F& E% m! D8 A/ G
       <customerid limit="1000">12341</customerid>! O6 }5 b/ c4 y1 v
( g. V5 ^6 R- W9 ]2 T* U+ _
       <status>pending</status>4 c6 z5 w& O& `( W; S* e
1 @/ Z6 m  k7 y7 H  b" k
       <item instock="Y" itemid="SA15">
% X1 j* I5 A9 ~. v4 N2 A+ C( O. D- k
          <name>Silver Show Saddle, 16 inch</name>
5 f9 E7 j3 @* r  z' L8 D
7 d6 @% F9 H- C; T, M  F          <price>825.00</price>6 g  r( H, m0 W* u9 @( g+ j
3 p) |, X/ O9 a
          <qty>1</qty>3 E! R! u3 d4 L" }- }( k1 |

" V9 U, a4 a) z  r; R       </item># J& H) P" a" X# ^" M

6 e6 l# L% i) H2 ?5 p       <item instock="N" itemid="C49">
, h2 x6 j3 I4 o4 [3 g6 J: x) ?. @( ^' \+ z& Z* T; V/ J- o
         <name>;Premium Cinch</name>
* Z& o4 J& M8 u9 M7 A5 o9 y4 L; ^' T( D8 N; N' Z: {# m
         <price>49.00</price>
! B2 ]! |. e  Y& B, U
1 k$ G# _1 M% u! v1 d         <qty>1</qty>/ ~7 B5 q$ h- w7 i7 e
. |4 r% v' k2 g4 r0 y0 d2 I
       </item>. x2 m# I1 N* I. X6 B

: g* p: ?3 V8 f2 |% z2 V& a  </order>
% K' M, w2 B' p0 a- v7 d" V5 D4 c  j$ c9 C. E
<order>. k, a9 z1 q% |' X8 T- W

8 f; f  n- M% M% g   <customerid limit="150">251222</customerid>
. |* \) r. c* `2 F+ K" M
* C& Z8 Q' S" ~# i! u   <status>pending</status>" U9 j% {* f) z; [$ _$ `
  d: ^( \9 [+ h8 z
   <item instock="Y" itemid="WB78">
0 `  L0 C" E; ?) {$ x
  o" e% S6 J2 r- c% n, }/ X     <name>Winter Blanket (78 inch)</name>
8 [( Z0 e. A- z% O- T0 y+ j8 `% a
4 ~# e+ g7 G) I9 G9 V( r     <price>20</price>
  [/ J# Y' R- S# c+ b6 m7 K  x1 Z' K5 G) t, R' ~# k
     <qty>10</qty>
- r: ~& j* N+ \6 w8 J/ J4 e% i) }  U/ K3 ~; b* E% b( i9 D( y
   </item>
, C( A8 X/ T% i
: ]' N- H3 V% a/ M& h5 F</order>4 Z6 e* }0 N. }4 @+ v3 I9 j
4 ^" A( K4 d- `2 G. P% `
</orders>% W* t8 j- I' n; B# R5 e
在 DOM 中,使用 XML 信息意味着首先将它划分为节点。





欢迎光临 捌玖网络工作室 (http://89w.org/) Powered by Discuz! 7.2