System.Xml.XmlNode.ReplaceChild 方法

方法描述

用 newChild 节点替换子节点 oldChild。

语法定义(C# System.Xml.XmlNode.ReplaceChild 方法 的用法)

public virtual XmlNode ReplaceChild(
	XmlNode newChild,
	XmlNode oldChild
)

参数/返回值

参数值/返回值 参数类型/返回类型 参数描述/返回描述
newChild System-Xml-XmlNode 要放入子列表的新节点。
oldChild System-Xml-XmlNode 列表中正在被替换的节点。
返回值 System.Xml.XmlNode 被替换的节点。

提示和注释

如果 newChild 已经在树中,则先将其移除。

如果 newChild 是从另一个文档中创建的,可使用 XmlDocument.ImportNode 将节点导入到当前文档。 然后可将导入的节点传递给 ReplaceChild 方法。

对继承者的说明

当在派生类中重写 ReplaceChild 时,若要使事件正确引发,必须调用基类的 ReplaceChild 方法。

System.Xml.XmlNode.ReplaceChild 方法例子

下面的示例替换 XML 中的标题元素。

using System;
using System.IO;
using System.Xml;

public class Sample {

  public static void Main() {

    XmlDocument doc = new XmlDocument();
    doc.LoadXml("" +
                "Pride And Prejudice" +
                "");

    XmlNode root = doc.DocumentElement;

    //Create a new title element.
    XmlElement elem = doc.CreateElement("title");
    elem.InnerText="The Handmaid's Tale";

    //Replace the title element.
    root.ReplaceChild(elem, root.FirstChild);

    Console.WriteLine("Display the modified XML...");
    doc.Save(Console.Out);

  }
}

异常

异常 异常描述
InvalidOperationException 此节点的类型不允许 newChild 节点类型的子节点。 newChild 是此节点的上级节点。
ArgumentException newChild 是从不同于创建此节点的文档创建的。 该节点是只读的。 oldChild 不是此节点的子级。

命名空间

namespace: System.Xml

程序集: System.Xml(在 System.Xml.dll 中)

版本信息

.NET Framework 受以下版本支持:4、3.5、3.0、2.0、1.1、1.0 .NET Framework Client Profile 受以下版本支持:4、3.5 SP1

适用平台

Windows 7, Windows Vista SP1 或更高版本, Windows XP SP3, Windows XP SP2 x64 Edition, Windows Server 2008(不支持服务器核心), Windows Server 2008 R2(支持 SP1 或更高版本的服务器核心), Windows Server 2003 SP2 .NET Framework 并不是对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求。