0

を使用しasp:XmlDataSourceてxmlドキュメントを一覧表示しています。次のようになります。

<asp:XmlDataSource ID="XmlDataSource1" runat="server" DataFile="~/App_Data/Xml/History.xml" />

そして、私はそれを次のasp:Listviewように使用しています:

<asp:ListView runat="server" DataSourceID="XmlDataSource1" >

xmlの最後の行をリストの最初の行にしたいので、順序を逆にする方法があるかどうか疑問に思いました。どうすればこれを達成できますか?

4

2 に答える 2

2

リストにデータを入力し、それを逆にして、そのリストにバインドするだけです。

編集:XMLファイルに完全に依存するため、例を示すのは難しいですが、基本的な考え方は以下のとおりです。必要に応じてselectステートメントを変更し、必要に応じてステートメントからいくつかを追加します。

XDocument XDoc = XDocument.Load(XMLFileName);
ListView.DataSource = (from XMLNode in XDoc.Nodes()
                       select XMLNode.ToString()).ToList().Reverse();
ListView.DataBind();
于 2011-05-04T12:20:42.300 に答える
2

xmlが次のようになっている場合(たとえば):

<myxml>
  <row id="1">
  <row id="2">
</myxml>

次に、次のようなインライン変換を実行できます。

<asp:XmlDataSource ID="XmlDataSource1" runat="server" DataFile="~/App_Data/Xml/History.xml">
  <Transform>   
    <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
     <xsl:template match="*">
     <myxml> 
        <xsl:for-each select="//row"> 
          <xsl:sort select="@id" order="descending" /> 
          <xsl:copy-of select="row"/> 
        </xsl:for-each> 
     </myxml>
    </xsl:template>
    </xsl:stylesheet>
</Transform>
</asp:XmlDataSource>

お役に立てば幸いです:)

于 2011-05-04T12:16:58.177 に答える