文件说:
XContainer.Nodes方法()
按文档顺序返回此元素或文档的子节点的集合.
备注
请注意,内容不包含属性.在LINQ to XML中,属性不被视为树的节点.它们是与元素关联的名称/值对.
XContainer.Elements方法()
按文档顺序返回此元素或文档的子元素的集合.
所以它看起来像Nodes()有一个限制,但那为什么它存在?使用节点()有任何可能的原因或优点吗?
解决方法
原因很简单:XNode是所有xml“parts”的基类(抽象)类,而XElement只是一个这样的部分(因此XElement是XNode的子类).考虑以下代码:
XDocument doc = XDocument.Parse("<root><el1 />some text<!-- comment --></root>"); foreach (var node in doc.Root.Nodes()) { Console.WriteLine(node); } foreach (var element in doc.Root.Elements()) { Console.WriteLine(element); }
第二个循环(通过Elements())将只返回一个项目:< el />
然而,第一个循环还将返回文本节点(一些文本)和注释节点(<! - comment - >),因此您可以看到差异.
您可以在XNode类的documentaiton中看到XNode的其他后代.