|
JavaTM Platform Standard Ed. 6 |
|||||||||
| 上一个类 下一个类 | 框架 无框架 | |||||||||
| 摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 | |||||||||
public interface Document
Document 接口表示整个 HTML 或 XML 文档。从概念上讲,它是文档树的根,并提供对文档数据的基本访问。
因为元素、文本节点、注释、处理指令等不能存在于 Document 的上下文之外,所以 Document 接口还包含所需的创建这些对象的工厂方法。所创建的 Node 对象具有 ownerDocument 属性,该属性将 Node 对象与创建这些对象时的上下文所属的 Document 关联起来。
另请参见 Document Object Model (DOM) Level 3 Core Specification。
| 字段摘要 |
|---|
| 方法摘要 | |
|---|---|
Node |
adoptNode(Node source)
试图把另一文档中的节点采用到此文档。 |
Attr |
createAttribute(String name)
创建给定名称的 Attr。 |
Attr |
createAttributeNS(String namespaceURI,
String qualifiedName)
创建给定的限定名称和名称空间 URI 的属性。 |
CDATASection |
createCDATASection(String data)
创建其值为指定字符串的 CDATASection 节点。 |
Comment |
createComment(String data)
创建给定指定字符串的 Comment 节点。 |
DocumentFragment |
createDocumentFragment()
创建空 DocumentFragment 对象。 |
Element |
createElement(String tagName)
创建指定类型的元素。 |
Element |
createElementNS(String namespaceURI,
String qualifiedName)
创建给定的限定名称和名称空间 URI 的元素。 |
EntityReference |
createEntityReference(String name)
创建 EntityReference 对象。 |
ProcessingInstruction |
createProcessingInstruction(String target,
String data)
创建给定指定名称和数据字符串的 ProcessingInstruction 节点。 |
Text |
createTextNode(String data)
创建给定指定字符串的 Text 节点。 |
DocumentType |
getDoctype()
与此文档相关的文档类型声明(参见 DocumentType)。 |
Element |
getDocumentElement()
这是一种便捷属性,该属性允许直接访问文档的文档元素的子节点。 |
String |
getDocumentURI()
文档的位置,如果未定义或 Document 是使用 DOMImplementation.createDocument 创建的,则为 null。 |
DOMConfiguration |
getDomConfig()
调用 Document.normalizeDocument() 时使用的配置。 |
Element |
getElementById(String elementId)
返回具有带给定值的 ID 属性的 Element。 |
NodeList |
getElementsByTagName(String tagname)
按文档顺序返回包含在文档中且具有给定标记名称的所有 Element 的 NodeList。 |
NodeList |
getElementsByTagNameNS(String namespaceURI,
String localName)
以文档顺序返回具有给定本地名称和名称空间 URI 的所有 Elements 的 NodeList。 |
DOMImplementation |
getImplementation()
处理此文档的 DOMImplementation 对象。 |
String |
getInputEncoding()
指定解析时此文档使用的编码的属性。 |
boolean |
getStrictErrorChecking()
指定是否强制执行错误检查的属性。 |
String |
getXmlEncoding()
作为 XML 声明的一部分,指定此文档编码的属性。 |
boolean |
getXmlStandalone()
作为 XML 声明的一部分,指定此文档是否为独立文档的属性。 |
String |
getXmlVersion()
作为 XML 声明 的一部分指定此文档版本号的属性。 |
Node |
importNode(Node importedNode,
boolean deep)
从另一文档向此文档导入节点,而不改变或移除原始文档中的源节点;此方法创建源节点的一个新副本。 |
void |
normalizeDocument()
此方法的行为如同使文档通过一个保存和加载的过程,而将其置为 "normal(标准)" 形式。 |
Node |
renameNode(Node n,
String namespaceURI,
String qualifiedName)
重命名 ELEMENT_NODE 或 ATTRIBUTE_NODE 类型的现有节点。 |
void |
setDocumentURI(String documentURI)
文档的位置,如果未定义或 Document 是使用 DOMImplementation.createDocument 创建的,则为 null。 |
void |
setStrictErrorChecking(boolean strictErrorChecking)
指定是否强制执行错误检查的属性。 |
void |
setXmlStandalone(boolean xmlStandalone)
作为 XML 声明 的一部分指定此文档是否是单独的的属性。 |
void |
setXmlVersion(String xmlVersion)
作为 XML 声明 的一部分指定此文档版本号的属性。 |
| 方法详细信息 |
|---|
DocumentType getDoctype()
DocumentType)。对于没有文档类型声明的 XML 文档,此方法返回 null。对于 HTML 文档,可以返回 DocumentType 对象,与 HTML 文档中是否有文档类型声明无关。Document 的子节点 DocumentType 节点的直接访问。此节点可以在文档创建时设置,以后可以通过使用子节点操作方法(如 Node.insertBefore 或 Node.replaceChild)进行更改。不过要注意的是,根据创建时指定的 DocumentType,在有些实现可以实例化不同类型的 Document 对象(支持 "Core" 之外的其他功能,如 "HTML" [DOM Level 2 HTML])时,以后对它的更改很可能会导致所支持功能的不可更改。
DOMImplementation getImplementation()
DOMImplementation 对象。DOM 应用程序可以使用多个实现中的对象。
Element getDocumentElement()
Element createElement(String tagName)
throws DOMException
Element 接口,所以可以直接在返回的对象上指定属性。Attr 节点,并将其连接到该元素。createElementNS 方法。
tagName - 要实例化的元素类型名称。对于 XML,tagName 参数是区分大小写的;而对于其他文档,则取决于所使用标记语言的大小写敏感性。在该情况下,可通过 DOM 实现将该名称映射到该标记的规范形式。
Element 对象,该对象具有设置为 tagName 的 nodeName 属性以及设置为 null 的 localName、prefix 和 namespaceURI。
DOMException - INVALID_CHARACTER_ERR:如果指定的名称是不遵循所使用的 XML 版本(在 Document.xmlVersion 属性中指定)的 XML 名称,则引发此异常。DocumentFragment createDocumentFragment()
DocumentFragment 对象。
DocumentFragment。Text createTextNode(String data)
Text 节点。
data - 该节点的数据。
Text 对象。Comment createComment(String data)
Comment 节点。
data - 该节点的数据。
Comment 对象。
CDATASection createCDATASection(String data)
throws DOMException
CDATASection 节点。
data - CDATASection 内容的数据。
CDATASection 对象。
DOMException - NOT_SUPPORTED_ERR:如果此文档为 HTML 文档,则引发该异常。
ProcessingInstruction createProcessingInstruction(String target,
String data)
throws DOMException
ProcessingInstruction 节点。
target - 处理指令的目标部分。与 Document.createElementNS 或 Document.createAttributeNS 不同,此方法不检查目标名称是否为格式良好的名称空间。为了确保目标名称是格式良好的名称空间,应用程序应该使用设置为 true 的参数 "namespaces" 调用 Document.normalizeDocument()。data - 该节点的数据。
ProcessingInstruction 对象。
DOMException - INVALID_CHARACTER_ERR:如果指定的目标是不遵循在 Document.xmlVersion 属性中指定的使用中的 XML 版本的 XML 名称,则引发此异常。
Attr createAttribute(String name)
throws DOMException
Attr。注意,然后可以使用 setAttributeNode 方法在 Element 上设置 Attr。createAttributeNS 方法。
name - 属性名称。
Attr 对象,该对象具有设置为 name 的 nodeName 属性以及设置为 null 的 localName、prefix 和 namespaceURI。该属性的值为空字符串。
DOMException - INVALID_CHARACTER_ERR:如果指定的名称是不遵循在 Document.xmlVersion 属性中指定的使用中的 XML 版本的 XML 名称,则引发此异常。
EntityReference createEntityReference(String name)
throws DOMException
EntityReference 对象。此外,如果引用的实体是已知的,则使 EntityReference 节点的子列表与相应 Entity 节点的子列表相同。
注: 如果任何 Entity 节点的后代具有未绑定的名称空间前缀,则相应的所创建的 EntityReference 节点的后代也未绑定;(其 namespaceURI 为 null)。DOM Level 2 和 3 不支持在此情况下解析名称空间前缀的任何机制。
name - 要引用的实体的名称。与 Document.createElementNS 或 Document.createAttributeNS 不同,不在实体名称上检查名称空间是否为格式良好的。为了确保实体名称是格式良好的名称空间,应用程序应该使用设置为 true 的参数 "namespaces" 调用 Document.normalizeDocument()。
EntityReference 对象。
DOMException - INVALID_CHARACTER_ERR:如果指定的名称是不遵循在 Document.xmlVersion 属性中指定的使用中的 XML 版本的 XML 名称,则引发此异常。 NodeList getElementsByTagName(String tagname)
Element 的 NodeList。
tagname - 要匹配的标记的名称。特殊值 "*" 匹配所有标记。对于 XML ,tagname 参数是区分大小写的,否则它将依靠正在使用的标记语言的大小写敏感性。
Elements 的新 NodeList 对象。
Node importNode(Node importedNode,
boolean deep)
throws DOMException
parentNode 为 null)。nodeName 和 nodeType,加上与名称空间相关的属性(prefix、localName 和 namespaceURI)。与在 cloneNode 操作中一样,源节点没有改变。与导入的节点相关的用户数据不可继续使用。不过,如果随相关数据一起指定了任何 UserDataHandlers,则将在此方法返回之前用适当的参数调用这些处理程序。nodeType 复制,在从一个文档向另一文档复制 XML 或 HTML 源的分段时试图镜像所需的行为,并认识到两个方法可以在 XML 实例中具有不同的 DTD。下表描述了每种类型节点的细节。
Attr 上,将 ownerElement 属性设置为 null 并将 specified 标志设置为 true。递归地导入源 Attr 的后代,并且重新集合得到的节点来构造相应的子树。注意,deep 参数对 Attr 节点无效;它们总是在导入时带着子节点。deep 选项设置为 true,则递归地导入源 DocumentFragment 的后代,并在导入的 DocumentFragment 下重新集合得到的节点以构造相应的子树。否则,此操作仅生成一个空 DocumentFragment。Document 节点。DocumentType 节点。Attr 节点连接到生成的 Element。默认属性是不 被复制的,不过,如果被导入的文档定义了此元素名称的默认属性,则分配这些属性。如果将 importNode deep 参数设置为 true,则递归地导入源元素的后代并集合得到的节点,以构造相应的子树。Entity 节点,但在当前版本的 DOM 中,DocumentType 是只读的。将考虑在以后版本的 DOM 中包含将这些导入的节点添加到 DocumentType 中这一功能。导入时,将复制 publicId、systemId 和 notationName 属性。如果请求 deep 导入,则递归地导入源 Entity 的后代,并重新集合得到的节点以构造相应的子树。deep 导入,也只复制 EntityReference 本身,因为源和目标文档可能以不同方式定义实体。如果正在导入的文档提供对此实体名称的定义,则它的值得以分配。Notation 节点,但在当前版本的 DOM 中,DocumentType 是只读的。能够将这些导入的节点添加到 DocumentType 将被认为是以后版本的 DOM 的附加功能。导入时,复制 publicId 和 systemId 属性。注意,deep 参数对此类型的节点无效,因为它们不能有任何子节点。target 和 data 值。注意,该 deep 参数对此类型的节点无效,因为它们不能有任何子节点。CharacterData 的这三种类型的节点从源节点复制其 data 和 length 属性。注意,deep 参数对这三种类型的节点无效,因为它们不能有任何子节点。
importedNode - 要导入的节点。deep - 如果为 true,则递归地导入在指定节点下的子树;如果为 false,则仅导入节点本身,如上面的解释。这对不能有任何子节点的节点、对 Attr 和 EntityReference 节点都无效。
Document 的节点。
DOMException - NOT_SUPPORTED_ERR:如果不支持正在导入的该类型的节点,则引发此异常。 Document.xmlVersion 属性中指定的使用中的 XML 版本的 XML 名称,则引发此异常。例如,将 XML 1.1 [XML 1.1] 元素导入 XML 1.0 文档时可能引发此异常。
Element createElementNS(String namespaceURI,
String qualifiedName)
throws DOMException
null 作为方法的 namespaceURI 参数的值。
namespaceURI - 要创建的元素的名称空间 URI。qualifiedName - 要实例化的元素类型的限定名称。
Element 对象:
| 属性 | 值 |
|---|---|
Node.nodeName |
qualifiedName |
Node.namespaceURI |
namespaceURI |
Node.prefix |
前缀,从 qualifiedName 中提取的;如果没有前缀,则为 null |
Node.localName |
本地名称,从 qualifiedName 提取的 |
Element.tagName |
qualifiedName |
DOMException - INVALID_CHARACTER_ERR:如果指定的 qualifiedName 是不遵循在 Document.xmlVersion 属性中指定的使用中的 XML 版本的 XML 名称,则引发此异常。 qualifiedName 是错误格式的限制名称;如果 qualifiedName 具有前缀且 namespaceURI 为 null;或者如果 qualifiedName 具有前缀 "xml" 且该 namespaceURI 不同于 "http://www.w3.org/XML/1998/namespace" [XML Namespaces];或者如果 qualifiedName 或其前缀为 "xmlns" 且该 namespaceURI 不同于 "http://www.w3.org/2000/xmlns/";或者如果 namespaceURI 为 "http://www.w3.org/2000/xmlns/" 且 qualifiedName 及其前缀都不是 "xmlns"。 "XML" 特性,则总是抛出此异常。
Attr createAttributeNS(String namespaceURI,
String qualifiedName)
throws DOMException
null 作为方法的 namespaceURI 参数的值。
namespaceURI - 要创建的属性的名称空间 URI。qualifiedName - 要实例化的属性的限定名称。
Attr 对象:
| 属性 | 值 |
|---|---|
Node.nodeName |
qualifiedName |
Node.namespaceURI |
namespaceURI |
Node.prefix |
前缀,从 qualifiedName 中提取的;如果没有前缀,则为 null |
Node.localName |
本地名称,从 qualifiedName 提取的 |
Attr.name |
qualifiedName |
Node.nodeValue |
空字符串 |
DOMException - INVALID_CHARACTER_ERR:如果指定的 qualifiedName 是不遵循在 Document.xmlVersion 属性中指定的使用中的 XML 版本的 XML 名称,则引发此异常。 qualifiedName 为错误格式的限定名称;如果 qualifiedName 有前缀且 namespaceURI 为 null;如果 qualifiedName 有前缀 "xml" 且 namespaceURI 不同于 "http://www.w3.org/XML/1998/namespace";如果 qualifiedName 或其前缀为 "xmlns" 且 namespaceURI 不同于 "http://www.w3.org/2000/xmlns/";或者 namespaceURI 为 "http://www.w3.org/2000/xmlns/" 且 qualifiedName 及其前缀都不是 "xmlns"。 "XML" 特性,则总是抛出此异常。
NodeList getElementsByTagNameNS(String namespaceURI,
String localName)
Elements 的 NodeList。
namespaceURI - 要匹配的元素的名称空间 URI。特殊值 "*" 匹配所有名称空间。localName - 要匹配的元素的本地名称。特殊值 "*" 匹配所有本地名称。
Elements 的新 NodeList 对象。Element getElementById(String elementId)
Element。如果不存在此类元素,则此方法返回 null。如果一个以上的元素具有带该值的 ID 属性,返回哪一个元素是不确定的。Attr.isId 来确定属性是否属于类型 ID。
注: 具有名称 "ID" 或 "id" 的属性不属于类型 ID,除非这样定义。
elementId - 元素的唯一 id 值。
null。String getInputEncoding()
Document 时),则为 null。
String getXmlEncoding()
Document 时,此属性为 null。
boolean getXmlStandalone()
false。
注: 设置此属性时不对此值进行任何验证。应用程序应该使用带有 "validate" 参数的 Document.normalizeDocument() 验证该值是否匹配在 [XML 1.0] 中定义的有关独立文档声明的有效性约束()。
void setXmlStandalone(boolean xmlStandalone)
throws DOMException
false。
注: 设置此属性时不对此值进行任何验证。应用程序应该使用带有 "validate" 参数的 Document.normalizeDocument() 验证该值是否匹配 validity constraint for standalone document declaration(在 [XML 1.0] 中定义)。
DOMException - NOT_SUPPORTED_ERR:如果此文档不支持 "XML" 特性,则引发此异常。String getXmlVersion()
"1.0"。如果此文档不支持 "XML" 特性,则该值始终为 null。更改此属性将影响在 XML 名称中检查无效字符的方法。应用程序应该调用 Document.normalizeDocument() 来检查在已经是此 Document 一部分的 Node 中的无效字符。DOMImplementation.hasFeature(feature, version) 方法来确定实现是否支持 [XML 1.0]。DOM 应用程序还可以使用参数值分别为 "XMLVersion" 和 "1.1"的同一方法来确定实现是否支持 [XML 1.1]。在这两种情况下,为了支持 XML,实现还必须支持在此规范中定义的 "XML" 特性。支持某版本的 "XMLVersion" 特性的 Document 对象不能在使用 Document.xmlVersion 时对相同版本号引发 NOT_SUPPORTED_ERR 异常。
void setXmlVersion(String xmlVersion)
throws DOMException
"1.0"。如果此文档不支持 "XML" 特性,则该值始终为 null。更改此属性将影响在 XML 名称中检查无效字符的方法。应用程序应该调用 Document.normalizeDocument() 来检查在已经是此 Document 一部分的 Node 中的无效字符。DOMImplementation.hasFeature(feature, version) 方法来确定实现是否支持 [XML 1.0]。DOM 应用程序还可以使用参数值分别为 "XMLVersion" 和 "1.1"的同一方法来确定实现是否支持 [XML 1.1]。在这两种情况下,为了支持 XML,实现还必须支持在此规范中定义的 "XML" 特性。支持某版本的 "XMLVersion" 特性的 Document 对象不能在使用 Document.xmlVersion 时对相同版本号引发 NOT_SUPPORTED_ERR 异常。
DOMException - NOT_SUPPORTED_ERR:如果将该版本设置为此 Document 不支持的值,或此文档不支持 "XML" 特性,则引发此异常。boolean getStrictErrorChecking()
false 时,该实现可以不测试通常在 DOM 操作上定义的每个可能的错误情形,可以不在 DOM 操作上引发任何 DOMException,也可以不在使用 Document.normalizeDocument() 时报告错误。如果发生错误,则该行为将会不确定。此属性默认为 true。
void setStrictErrorChecking(boolean strictErrorChecking)
false 时,该实现不会随意测试通常在 DOM 操作上定义的每个可能的错误情形,不会在 DOM 操作上引发任何 DOMException,也不会在使用 Document.normalizeDocument() 时报告错误。如果发生错误,则该行为不确定。此属性默认为 true。
String getDocumentURI()
Document 是使用 DOMImplementation.createDocument 创建的,则为 null。设置此属性时不执行任何词汇检查;这可能导致在使用 Node.baseURI 时返回 null 值。Document 支持 "HTML" [DOM Level 2 HTML] 特性,则计算 Node.baseURI 时 HTML BASE 元素的 href 属性优先于此属性。
void setDocumentURI(String documentURI)
Document 是使用 DOMImplementation.createDocument 创建的,则为 null。设置此属性时不执行任何词汇检查;这可能导致在使用 Node.baseURI 时返回 null 值。Document 支持 "HTML" [DOM Level 2 HTML] 特性,则计算 Node.baseURI 时 HTML BASE 元素的 href 属性优先于此属性。
Node adoptNode(Node source)
throws DOMException
ownerDocument、它的子节点以及连接的属性节点(如果有)。如果源节点有父节点,则首先从其父节点的子节点列表中移除它。此方法允许将子树从一个文档移动到另一个文档(与 importNode() 不同,后者创建源节点副本,而不是移动子树)。失败时,应用程序应该改为使用 Document.importNode()。注意,如果采用的节点已经是此文档的一部分(即源文档和目标文档相同),此方法仍可有效地从其父节点(如果有)的子列表移除源节点。下表描述了每种类型节点的细节。
Attr 上,将 ownerElement 属性设置为 null 并将 specified 标志设置为 true。递归地采用源 Attr 的后代。Document 节点。DocumentType 节点。Entity 节点。EntityReference 节点本身并丢弃其后代,因为源文档和目标文档可能以不同方式定义实体。如果要导入的文档提供了对此实体名称的定义,则分配其值。Notation 节点。注: 由于它与 Document.importNode() 方法不同,不创建新的节点,因此此方法不引发 INVALID_CHARACTER_ERR 异常,并且应用程序应该使用 Document.normalizeDocument() 方法来检查导入的名称是否是遵循正在使用的 XML 版本的 XML 名称。
source - 要移入此文档的节点。
null。
DOMException - NOT_SUPPORTED_ERR:如果源节点属于 DOCUMENT、DOCUMENT_TYPE 类型,则引发此异常。 DOMConfiguration getDomConfig()
Document.normalizeDocument() 时使用的配置。
void normalizeDocument()
EntityReference 节点的替换树并规范化 Text 节点,如在方法 Node.normalize() 中定义的那样。Document.domConfig 对象上设置的、控制哪个操作实际发生的特性。值得注意的是,此方法还可以按照其中描述的算法使文档名称空间格式良好、检查字符规范化、移除 CDATASection 节点,等等。有关详细信息请参见 DOMConfiguration。
// Keep in the document
the information defined // in the XML Information Set (Java example)
DOMConfiguration docConfig = myDocument.getDomConfig();
docConfig.setParameter("infoset", Boolean.TRUE);
myDocument.normalizeDocument();
Node.nodeName 包含无效字符,则将使用与 "error-handler" 参数相关联的 DOMErrorHandler 对象报告错误或警告(DOMError.SEVERITY_ERROR 或 DOMError.SEVERITY_WARNING)。注意,如果实现无法从错误中恢复,则此方法还可能报告严重错误(DOMError.SEVERITY_FATAL_ERROR)。
Node renameNode(Node n,
String namespaceURI,
String qualifiedName)
throws DOMException
ELEMENT_NODE 或 ATTRIBUTE_NODE 类型的现有节点。Element,则其属性移动到新节点;将新节点插入旧节点原来在其父(如果有)的子节点列表中的位置;将连接到旧节点的用户数据连接到新节点。Element 时,只移动指定的属性,源于 DTD 的默认属性按照新的元素名称更新。此外,实现还可以更新源自其他模式的默认属性。应用程序应该使用 Document.normalizeDocument() 来保证这些属性是最新的。Element 的 Attr 时,则首先从 Element 属性映射中移除该节点。然后,一旦通过修改现有节点或创建新节点(如上所述)重命名,则将它放回原处。NODE_RENAMED,
http://www.w3.org/2001/xml-events DOMElementNameChanged} 或 { http://www.w3.org/2001/xml-events DOMAttributeNameChanged}。
n - 要重命名的节点。namespaceURI - 新的名称空间 URI。qualifiedName - 新的限定名称。
DOMException - NOT_SUPPORTED_ERR:当指定节点的类型不是 ELEMENT_NODE,也不是 ATTRIBUTE_NODE 时,或者如果实现不支持重命名文档元素,则引发此异常。 Document.xmlVersion 属性中指定的 XML 版本的 XML 名称,则引发此异常。 qualifiedName 为错误格式的限定名称;如果 qualifiedName 有前缀且 namespaceURI 为 null;或者如果 qualifiedName 有前缀 "xml" 且 namespaceURI 不同于 "http://www.w3.org/XML/1998/namespace" [XML Namespaces]。当正被重命名的节点为一属性时,如果 qualifiedName 或其前缀为 "xmlns" 且 namespaceURI 不同于 "http://www.w3.org/2000/xmlns/",也引发此异常。
|
JavaTM Platform Standard Ed. 6 |
|||||||||
| 上一个类 下一个类 | 框架 无框架 | |||||||||
| 摘要: 嵌套 | 字段 | 构造方法 | 方法 | 详细信息: 字段 | 构造方法 | 方法 | |||||||||
版权所有 2007 Sun Microsystems, Inc. 保留所有权利。 请遵守许可证条款。另请参阅文档重新分发政策。