XContainer.ReplaceNodes 方法

定义

使用指定内容替换此文档或元素的子节点。

重载

ReplaceNodes(Object)

使用指定内容替换此文档或元素的子节点。

ReplaceNodes(Object[])

使用指定内容替换此文档或元素的子节点。

示例

以下示例创建两个 XML 树,然后使用此方法将其中一个树的内容替换为查询结果。

C#
XElement root = new XElement("Root",  
    new XElement("Child", 1),  
    new XElement("Child", 2),  
    new XElement("Child", 3),  
    new XElement("Child", 4),  
    new XElement("Child", 5)  
);  
root.ReplaceNodes(  
    from el in root.Elements()  
    where (int)el >= 3  
    select el  
);  
Console.WriteLine(root);  

该示例产生下面的输出:

XML
<Root>  
  <Child>3</Child>  
  <Child>4</Child>  
  <Child>5</Child>  
</Root>  

注解

有关可传递给此函数的有效内容的详细信息,请参阅 XElement 和 XDocument 对象的有效内容

此方法将引发 ChangedChanging 事件。

此方法具有快照语义。 它首先创建新内容的副本。 然后,它会删除此节点的所有子节点。 最后,它将新内容添加为子节点。 这意味着可以使用子节点本身的查询来替换子节点。

ReplaceNodes(Object)

Source:
XContainer.cs
Source:
XContainer.cs
Source:
XContainer.cs

使用指定内容替换此文档或元素的子节点。

C#
public void ReplaceNodes (object content);
C#
public void ReplaceNodes (object? content);

参数

content
Object

用于替换子节点的包含简单内容的内容对象或内容对象集合。

示例

以下示例创建一个包含子节点的 XML 树。 然后,它将所有子节点替换为单个元素。

若要查看将子节点替换为 LINQ 查询结果的示例,请参阅 ReplaceNodes

C#
XElement root = new XElement("Root",  
    new XElement("Child", 1),  
    new XElement("Child", 2),  
    new XElement("Child", 3),  
    new XElement("Child", 4),  
    new XElement("Child", 5)  
);  
root.ReplaceNodes(  
    from el in root.Elements()  
    where (int)el >= 3  
    select el  
);  
Console.WriteLine(root);  

该示例产生下面的输出:

XML
<Root>  
  <Child>3</Child>  
  <Child>4</Child>  
  <Child>5</Child>  
</Root>  

注解

有关可传递给此函数的有效内容的详细信息,请参阅 XElement 和 XDocument 对象的有效内容

此方法将引发 ChangedChanging 事件。

此方法具有快照语义。 它首先创建新内容的副本。 然后,它会删除此节点的所有子节点。 最后,它将新内容添加为子节点。 这意味着可以使用子节点本身的查询来替换子节点。

另请参阅

适用于

.NET 9 和其他版本
产品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

ReplaceNodes(Object[])

Source:
XContainer.cs
Source:
XContainer.cs
Source:
XContainer.cs

使用指定内容替换此文档或元素的子节点。

C#
public void ReplaceNodes (params object[] content);
C#
public void ReplaceNodes (params object?[] content);

参数

content
Object[]

内容对象的参数列表。

示例

以下示例创建字典和 XML 树。 然后,它会查询字典,将结果投影到 的 XElementIEnumerable<T>并将 XML 树的内容替换为查询结果。

C#
XElement root = new XElement("Root",  
    new XElement("Child", 1),  
    new XElement("Child", 2),  
    new XElement("Child", 3),  
    new XElement("Child", 4),  
    new XElement("Child", 5)  
);  
root.ReplaceNodes(  
    from el in root.Elements()  
    where (int)el >= 3  
    select el  
);  
Console.WriteLine(root);  

该示例产生下面的输出:

XML
<Root>  
  <Child>3</Child>  
  <Child>4</Child>  
  <Child>5</Child>  
</Root>  

注解

有关可传递给此函数的有效内容的详细信息,请参阅 XElement 和 XDocument 对象的有效内容

此方法将引发 ChangedChanging 事件。

此方法具有快照语义。 它首先创建新内容的副本。 然后,它会删除此节点的所有子节点。 最后,它将新内容添加为子节点。 这意味着可以使用子节点本身的查询来替换子节点。

另请参阅

适用于

.NET 9 和其他版本
产品 版本
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0