带有过滤器绑定到DropDownList的XMLDataSource

时间:2011-12-06 12:51:55

标签: c# asp.net xmldatasource

我有一个XML

<AddressTypes>
  <AddressType name="OFFICE" value="OFFICE" status="true"/>
  <AddressType name="HOME" value="HOME" status="true"/>
  <AddressType name="PRIVATE" value="PRIVATE" status="false"/>
</AddressTypes>

我将它绑定到类似

的DropDownList
<asp:DropDownList ID="AddressTypesList" runat="server"
            AppendDataBoundItems="true"
            CssClass="selectbox" 
            DataSourceID="AddressesXMLSource"
            DataTextField="name"
            DataValueField="value">
    <asp:ListItem Text="ALL" Value=""></asp:ListItem>
</asp:DropDownList>
<asp:XmlDataSource ID="AddressesXMLSource" runat="server" 
        DataFile="~/App_Data/AdressTypes.xml" 
        XPath="/AddressTypes/AddressType">
</asp:XmlDataSource>

我在这里得到了所有三个字段。但我想过滤结果,以便我可以只填充AddressType,其中status =“true”。怎么做?

1 个答案:

答案 0 :(得分:3)

尝试修改XmlDataSource中的XPath以包含[@status ='true']以仅包含与“true”状态匹配的元素。

您的新xpath字符串将如下所示:

/AddressTypes/AddressType[ @status = 'true' ]