Extensions.CreateNavigator メソッド

定義

XPathNavigatorXNode を作成します。Creates an XPathNavigator for an XNode.

オーバーロード

CreateNavigator(XNode)

XPathNavigatorXNode を作成します。Creates an XPathNavigator for an XNode.

CreateNavigator(XNode, XmlNameTable)

XPathNavigatorXNode を作成します。Creates an XPathNavigator for an XNode. XmlNameTable を使用すると、XPath 式をより効率的に処理できます。The XmlNameTable enables more efficient XPath expression processing.

注釈

このメソッドによって返さXPathNavigatorれるを使用して XML ツリーを編集することはできません。You cannot edit the XML tree by using the XPathNavigator that is returned by this method. CanEdit プロパティは、false を返します。The CanEdit property returns false.

XPathNavigatorノードのを作成することはできません。 XDocumentTypeYou cannot create an XPathNavigator for a XDocumentType node. ドキュメントの種類は、XPath データモデルには含まれません。Document types do not participate in the XPath data model.

名前空間宣言は左から右へと報告されます。Namespace declarations are reported from left to right. これに対してXmlDocument 、名前空間は右から左へと報告されます。In contrast, for XmlDocument namespaces are reported from right to left. これは、XPath データモデルでは名前空間宣言が順序付けられていないため、準拠した動作です。This is conformant behavior because namespace declarations are not ordered in the XPath data model.

メソッドMoveToIdは、このメソッドによって返されるナビゲーターではサポートされていません。The method MoveToId is not supported for navigators that are returned by this method.

このメソッドを使用して、XSLT 変換を実行できます。You can use this method to perform an XSLT transformation. Xml ツリーを作成し、xml ツリー XPathNavigatorからを作成して、新しいドキュメントを作成し、新しいドキュメントに書き込むをXmlWriter作成できます。You can create an XML tree, create an XPathNavigator from the XML tree, create a new document, and create a XmlWriter that will write into the new document. 次に、XSLT 変換を呼び出し、変換処理に XPathNavigator および XmlWriter を渡すことができます。Then, you can invoke the XSLT transformation, passing the XPathNavigator and XmlWriter to the transformation. 変換が正常に完了すると、新しい XML ツリーに変換結果が挿入されます。After the transformation successfully completes, the new XML tree is populated with the results of the transformation.

XSLT 変換を実行するにXmlReader XPathNavigatorは、またはを使用できます。To perform an XSLT transformation, you can use either an XmlReader or an XPathNavigator. 2つの方法には、パフォーマンス特性が異なります。The two approaches have different performance characteristics. を使用XmlReaderすると、一部の変換が高速に実行されXPathNavigatorます。また、を使用すると、他の変換が高速に実行されます。Some transformations will execute faster when using an XmlReader, and others will execute faster when using a XPathNavigator. パフォーマンスに問題がある場合は、各アプローチを試して、状況に応じてどのようなパフォーマンスが向上するかを判断することをお勧めします。If performance is a concern, we recommend that you experiment with each approach to determine which will perform better in your circumstances.

  
            string xslMarkup = @"<?xml version='1.0'?>  
<xsl:stylesheet xmlns:xsl='http://www.w3.org/1999/XSL/Transform' version='1.0'>  
    <xsl:template match='/Parent'>  
        <Root>  
            <C1><xsl:value-of select='Child1'/></C1>  
            <C2><xsl:value-of select='Child2'/></C2>  
        </Root>  
    </xsl:template>  
</xsl:stylesheet>";  
  
XDocument xmlTree = new XDocument(  
    new XElement("Parent",  
        new XElement("Child1", "Child1 data"),  
        new XElement("Child2", "Child2 data")  
    )  
);  
  
XDocument newTree = new XDocument();  
using (XmlWriter writer = newTree.CreateWriter()) {  
    // Load the style sheet.  
    XslCompiledTransform xslt = new XslCompiledTransform();  
    xslt.Load(XmlReader.Create(new StringReader(xslMarkup)));  
  
    // Execute the transform and output the results to a writer.  
    xslt.Transform(xmlTree.CreateNavigator(), writer);  
}  
  
Console.WriteLine(newTree);  
  
            Dim xslMarkup As XDocument = <?xml version='1.0'?>  
                             <xsl:stylesheet xmlns:xsl='http://www.w3.org/1999/XSL/Transform' version='1.0'>  
                                 <xsl:template match='/Parent'>  
                                     <Root>  
                                         <C1><xsl:value-of select='Child1'/></C1>  
                                         <C2><xsl:value-of select='Child2'/></C2>  
                                     </Root>  
                                 </xsl:template>  
                             </xsl:stylesheet>  
  
Dim xmlTree As XDocument = <?xml version='1.0'?>  
                           <Parent>  
                               <Child1>Child1 data</Child1>  
                               <Child2>Child2 data</Child2>  
                           </Parent>  
  
Dim newTree As XDocument = New XDocument()  
  
Using writer As XmlWriter = newTree.CreateWriter()  
    ' Load the style sheet.  
    Dim xslt As XslCompiledTransform = _  
        New XslCompiledTransform()  
    xslt.Load(xslMarkup.CreateReader())  
  
    ' Execute the transform and output the results to a writer.  
    xslt.Transform(xmlTree.CreateNavigator(), writer)  
End Using  
  
Console.WriteLine(newTree)  

この例を実行すると、次の出力が生成されます。This example produces the following output:

  
            <Root>  
  <C1>Child1 data</C1>  
  <C2>Child2 data</C2>  
</Root>  

CreateNavigator(XNode)

XPathNavigatorXNode を作成します。Creates an XPathNavigator for an XNode.

public:
[System::Runtime::CompilerServices::Extension]
 static System::Xml::XPath::XPathNavigator ^ CreateNavigator(System::Xml::Linq::XNode ^ node);
public static System.Xml.XPath.XPathNavigator CreateNavigator (this System.Xml.Linq.XNode node);
static member CreateNavigator : System.Xml.Linq.XNode -> System.Xml.XPath.XPathNavigator
<Extension()>
Public Function CreateNavigator (node As XNode) As XPathNavigator

パラメーター

node
XNode

XPath クエリを処理できる XNodeAn XNode that can process XPath queries.

戻り値

XPath クエリを処理できる XPathNavigatorAn XPathNavigator that can process XPath queries.

  
                string xslMarkup = @"<?xml version='1.0'?>  
<xsl:stylesheet xmlns:xsl='http://www.w3.org/1999/XSL/Transform' version='1.0'>  
    <xsl:template match='/Parent'>  
        <Root>  
            <C1><xsl:value-of select='Child1'/></C1>  
            <C2><xsl:value-of select='Child2'/></C2>  
        </Root>  
    </xsl:template>  
</xsl:stylesheet>";  
  
XDocument xmlTree = new XDocument(  
    new XElement("Parent",  
        new XElement("Child1", "Child1 data"),  
        new XElement("Child2", "Child2 data")  
    )  
);  
  
XDocument newTree = new XDocument();  
using (XmlWriter writer = newTree.CreateWriter()) {  
    // Load the style sheet.  
    XslCompiledTransform xslt = new XslCompiledTransform();  
    xslt.Load(XmlReader.Create(new StringReader(xslMarkup)));  
  
    // Execute the transform and output the results to a writer.  
    xslt.Transform(xmlTree.CreateNavigator(), writer);  
}  
  
Console.WriteLine(newTree);  
  
                Dim xslMarkup As XDocument = _  
    <?xml version='1.0'?>  
    <xsl:stylesheet xmlns:xsl='http://www.w3.org/1999/XSL/Transform' version='1.0'>  
        <xsl:template match='/Parent'>  
            <Root>  
                <C1><xsl:value-of select='Child1'/></C1>  
                <C2><xsl:value-of select='Child2'/></C2>  
            </Root>  
        </xsl:template>  
    </xsl:stylesheet>  
  
Dim xmlTree As XDocument = _  
    <?xml version='1.0'?>  
    <Parent>  
        <Child1>Child1 data</Child1>  
        <Child2>Child2 data</Child2>  
    </Parent>  
  
Dim newTree As XDocument = New XDocument()  
  
Using writer As XmlWriter = newTree.CreateWriter()  
    ' Load the style sheet.  
    Dim xslt As XslCompiledTransform = _  
        New XslCompiledTransform()  
    xslt.Load(xslMarkup.CreateReader())  
  
    ' Execute the transform and output the results to a writer.  
    xslt.Transform(xmlTree.CreateNavigator(), writer)  
End Using  
  
Console.WriteLine(newTree)  

この例を実行すると、次の出力が生成されます。This example produces the following output:

  
                <Root>  
  <C1>Child1 data</C1>  
  <C2>Child2 data</C2>  
</Root>  

注釈

このメソッドによって返さXPathNavigatorれるを使用して XML ツリーを編集することはできません。You cannot edit the XML tree by using the XPathNavigator that is returned by this method. CanEdit プロパティは、false を返します。The CanEdit property returns false.

XPathNavigatorノードのを作成することはできません。 XDocumentTypeYou cannot create an XPathNavigator for a XDocumentType node. ドキュメントの種類は、XPath データモデルには含まれません。Document types do not participate in the XPath data model.

名前空間宣言は左から右へと報告されます。Namespace declarations are reported from left to right. これに対してXmlDocument 、名前空間は右から左へと報告されます。In contrast, for XmlDocument namespaces are reported from right to left. これは、XPath データモデルでは名前空間宣言が順序付けられていないため、準拠した動作です。This is conformant behavior because namespace declarations are not ordered in the XPath data model.

メソッドMoveToIdは、このメソッドによって返されるナビゲーターではサポートされていません。The method MoveToId is not supported for navigators that are returned by this method.

このメソッドを使用して、XSLT 変換を実行できます。You can use this method to perform an XSLT transformation. Xml ツリーを作成し、xml ツリー XPathNavigatorからを作成して、新しいドキュメントを作成し、新しいドキュメントに書き込むをXmlWriter作成できます。You can create an XML tree, create an XPathNavigator from the XML tree, create a new document, and create a XmlWriter that will write into the new document. 次に、XSLT 変換を呼び出して、 XPathNavigatorXmlWriterを変換に渡します。Then, you can invoke the XSLT transformation, passing the XPathNavigator and XmlWriter to the transform. 変換が正常に完了すると、新しい XML ツリーに変換結果が挿入されます。After the transformation successfully completes, the new XML tree is populated with the results of the transformation.

XSLT 変換を実行するにXmlReader XPathNavigatorは、またはを使用できます。To perform an XSLT transformation, you can use either an XmlReader or an XPathNavigator. 2つの方法には、パフォーマンス特性が異なります。The two approaches have different performance characteristics. を使用XmlReaderすると、一部の変換が高速に実行されXPathNavigatorます。また、を使用すると、他の変換が高速に実行されます。Some transformations will execute faster when using an XmlReader, and others will execute faster when using a XPathNavigator. パフォーマンスに問題がある場合は、各アプローチを試して、状況に応じてどのようなパフォーマンスが向上するかを判断することをお勧めします。If performance is a concern, we recommend that you experiment with each approach to determine which will perform better in your circumstances.

CreateNavigator(XNode, XmlNameTable)

XPathNavigatorXNode を作成します。Creates an XPathNavigator for an XNode. XmlNameTable を使用すると、XPath 式をより効率的に処理できます。The XmlNameTable enables more efficient XPath expression processing.

public:
[System::Runtime::CompilerServices::Extension]
 static System::Xml::XPath::XPathNavigator ^ CreateNavigator(System::Xml::Linq::XNode ^ node, System::Xml::XmlNameTable ^ nameTable);
public static System.Xml.XPath.XPathNavigator CreateNavigator (this System.Xml.Linq.XNode node, System.Xml.XmlNameTable nameTable);
static member CreateNavigator : System.Xml.Linq.XNode * System.Xml.XmlNameTable -> System.Xml.XPath.XPathNavigator
<Extension()>
Public Function CreateNavigator (node As XNode, nameTable As XmlNameTable) As XPathNavigator

パラメーター

node
XNode

XPath クエリを処理できる XNodeAn XNode that can process an XPath query.

nameTable
XmlNameTable

XmlNameTable で使用する XPathNavigatorA XmlNameTable to be used by XPathNavigator.

戻り値

XPath クエリを処理できる XPathNavigatorAn XPathNavigator that can process XPath queries.

注釈

このメソッドによって返さXPathNavigatorれるを使用して XML ツリーを編集することはできません。You cannot edit the XML tree using the XPathNavigator that is returned by this method. CanEdit プロパティは、false を返します。The CanEdit property returns false.

XPathNavigatorノードのを作成することはできません。 XDocumentTypeYou cannot create an XPathNavigator for a XDocumentType node. ドキュメントの種類は、XPath データモデルには含まれません。Document types do not participate in the XPath data model.

名前空間宣言は左から右へと報告されます。Namespace declarations are reported from left to right. これに対してXmlDocument 、名前空間は右から左へと報告されます。In contrast, for XmlDocument namespaces are reported from right to left. これは、XPath データモデルでは名前空間宣言が順序付けられていないため、準拠した動作です。This is conformant behavior because namespace declarations are not ordered in the XPath data model.

メソッドMoveToIdは、このメソッドによって返されるナビゲーターではサポートされていません。The method MoveToId is not supported for navigators that are returned by this method.

このメソッドXmlNameTableでを使用してXPathNavigatorを作成すると、XPath 式を評価するときのパフォーマンスが向上します。If you use an XmlNameTable with this method to create the XPathNavigator, you will get better performance when evaluating XPath expressions.

適用対象