0

对于像下面这样的 xml 文档,我会显示当前所选文件夹的所有子文件夹和文件。为此,我从 xml 字符串中删除了不匹配的文件夹并在前端使用 XSLT 构建了一个 UI。似乎该操作正在删除使结果字符串无效的 xml 的所有节点。所以

  • 如何在不更改文档有效性的情况下使用 Linq to Xml 从 xml 中删除元素

xml文件

<?xml version="1.0" encoding="utf-8"?>
<Folder>
  <Folders>
    <Folder ID="1" Name="Root" ParentId="0">
      <Files></Files>
    </Folder>
    <Folder ID="2" Name="My Documents" ParentId="1">
      <Files>
        <File Name="LicenceCode.txt" Size="2000" CreatedOn="1/1/2012 12:12:00 PM" CreatedBy="1" ModifiedOn="1/10/2012 10:12:56 AM" ModifiedBy="2"></File>
      </Files>
    </Folder>
  </Folders>
</Folder>

代码

XElement filesAndFolders = XElement.Parse(xmlDocumentString);
string outputFolders = string.concat(from folders in filesAndFolders in filesAndFolder.Elements("Folder").Folder("Folders") where folders.Attribute("ParentId").Value.Equals(selectedFolderId) select folders);
//pass outputFolders string to xsl to build the UI

问题

outputFolders字符串无效,因为它仅包含以下字符串而不是有效文档

<Folder ID="2" Name="My Documents" ParentId="1">
  <Files>
    <File Name="LicenceCode.txt" Size="2000" CreatedOn="1/1/2012 12:12:00 PM" CreatedBy="1" ModifiedOn="1/10/2012 10:12:56 AM" ModifiedBy="2"></File>
  </Files>
</Folder>
4

1 回答 1

1

如何删除您不想要的元素:

        var doc = XDocument.Parse(xmlString);

        doc.Element("Folder").Element("Folders").Elements("Folder").Where(f => f.Attribute("ID").Value == "1").Remove();
于 2012-06-22T09:57:42.600 回答