我有一个XML文档,想要做语法高亮。
代码使用XPathDocument,XPathNavigator和XPathNodeIterator。 在我调用Select()之后,如何在XML文档中获取原始文本?
var xpathDoc = new XPathDocument(new StringReader(this.richTextBox1.Text));
var nav = xpathDoc.CreateNavigator();
XmlNamespaceManager xmlns = new XmlNamespaceManager(nav.NameTable);
xmlns.AddNamespace("ns1", "urn:myxnlnamespace");
XPathNodeIterator selection = nav.Select(xpathExpression, xmlns);
foreach (XPathNavigator node in selection)
{
// Here, node.OuterXml includes an explicit namespace.
// If the original raw xml fragment for this node was
// <ElementName>Text</ElementName>
// and if xmlns="urn:myxnlnamespace" is used on the root of the document....
//
// OuterXml will return
// <ElementName xmlns="urn:myxnlnamespace">Text</ElementName>
//
// InnerXml will return "Text" in this example.
//
// How can I get the original, raw XML bytestream for this node?
// Like this:
// <ElementName>Text</ElementName>
//
}
对我来说,获取所选节点的开头和结尾的IXmlLineInfo也是有用的。 现在我可以移动到所选节点的开头并获取IXmlLineInfo。但我只知道如何移动到下一个节点(MoveToNext());不知道如何移动到当前节点的 end 。如果所讨论的节点是序列中的最后一个节点(不再有兄弟节点),则此方法也不起作用。
如果有一些xpath表达式返回当前节点的完整原始文本,它也会起作用。到目前为止,我找不到类似的东西。
编辑:我通过一个无耻的黑客来解决这个问题。要确定我需要突出显示的文本的长度,我手动解析原始的xml文本,搜索尖括号和名称标记。它并不漂亮,但在没有更好的东西的情况下,它适用于简单的XML文件。
如果有人的话,我仍然对真正的答案感兴趣。