将现有节点从一个文档复制到另一个文档
ImportNode 方法是一种机制,用于将节点或整个节点子树从一个 XmlDocument 复制到另一个 XmlDocument。 该调用返回的节点是源文档节点的副本,其中包括属性值、节点名、节点类型以及所有与命名空间相关的属性,如前缀、本地名称和命名空间统一资源标识符 (URI)。 源文档不更改。 导入该节点后,仍需使用插入节点的方法之一将该节点添加到树中。
节点附加到新文档后,将归此新文档所有。 原因是每个节点在创建后都具有所属文档,即使节点是在单独的文档片段中创建的。 这是 XML 文档对象模型 (DOM) 要求,由 XmlDocument 类的工厂创建设计强制执行。 例如,CreateElement 是新建节点的唯一方法。
根据导入节点的节点类型和 deep 参数的值,还会适当复制其他信息。 此方法尝试镜像当 XML 或 HTML 源代码片断从一个文档复制到另一个文档时的预期行为,并且考虑到对于 XML,两个文档可能具有不同的文档类型定义 (DTD)。
下表描述了可导入的每种节点类型的特定行为。
节点类型 | deep 参数为 true | deep 参数为 false |
---|---|---|
XmlAttribute | 在 XmlAttribute 上,Specified 设置为 true。 递归导入源 XmlAttribute 的子代,并重组生成的节点,以构成相应的子树。 | deep 参数不适用于 XmlAttribute 节点,因为这些节点在导入时总是带子节点。 |
XmlCDataSection | 复制该节点,包括复制其数据。 | 复制该节点,包括复制其数据。 |
XmlComment | 复制该节点,包括复制其数据。 | 复制该节点,包括复制其数据。 |
XmlDocumentFragment | 递归导入源节点的子代,并重组生成的节点,以构成相应的子树。 | 创建空的 XmlDocumentFragment 。 |
XmlDocumentType | 复制该节点,包括复制其数据。* | 复制该节点,包括复制其数据。* |
XmlElement | 递归导入源元素的子代,并重组生成的节点,以构成相应的子树。 注意:不复制默认属性。 如果导入到的文档定义该元素名称的默认属性,则分配这些默认属性。 | 导入源元素的指定属性节点,并将生成的 XmlAttribute 节点附加到新元素。 不复制子代节点。 注意:不复制默认属性。 如果导入到的文档定义该元素名称的默认属性,则分配这些默认属性。 |
XmlEntityReference | 因为源文档和目标文档可能以不同的方式定义实体,所以此方法仅复制 XmlEntityReference 节点。 不包括替换文本。 如果目标文档定义了实体,则给它赋值。 | 因为源文档和目标文档可能以不同的方式定义实体,所以此方法仅复制 XmlEntityReference 节点。 不包括替换文本。 如果目标文档定义了实体,则给它赋值。 |
XmlProcessingInstruction | 从导入的节点复制目标和数据值。 | 从导入的节点复制目标和数据值。 |
XmlText | 复制该节点,包括复制其数据。 | 复制该节点,包括复制其数据。 |
XmlSignificantWhitespace | 复制该节点,包括复制其数据。 | 复制该节点,包括复制其数据。 |
XmlWhitespace | 复制该节点,包括复制其数据。 | 复制该节点,包括复制其数据。 |
XmlDeclaration | 从导入的节点复制目标和数据值。 | 从导入的节点复制目标和数据值。 |
所有其他节点类型 | 不能导入这些节点类型。 | 不能导入这些节点类型。 |
注意
虽然可以导入 DocumentType 节点,但一个文档只能有一个 DocumentType。 因此,导入该文档类型后,在将其插入到树中之前,必须确保文档中没有任何文档类型。 若要了解如何删除节点,请参阅从 XML 文档中删除节点、内容和值。