如何使用LINQ填充具有多个值的asp列表框?

时间:2013-04-04 14:35:24

标签: c# asp.net

我的列表框没有显示数据,只有classdata名称:

    XDocument doc = XDocument.Parse(XMLfile);
    List<ClassData> data = (from item in doc.Descendants("freq")
         where item.Element("ID").Value > 50
         orderby item.Element("Time").Value
         select new ClassData
         {
              ID= item.Element("ID").Value,
              Name= item.Element("Name").Value,
              Age= item.Element("Age").Value,
              Time= item.Element("Time").Value
          }).ToList<ClassData>();
    lstBox.DataSource = data;
    lstBox.DataBind();

myclassdata:

 public class ClassData
{
    public string ID{ get; set; }
    public string Name{ get; set; }
    public string Age{ get; set; }
    public string Time{ get; set; }
}

我在列表框中添加了4个项目,其中包含了我的classData项目的相同名称... 我的结果是:SolutionName.ClassData 32次(结果数)

2 个答案:

答案 0 :(得分:1)

默认情况下,列表框会显示您提供的项目ToString()的结果,就像您说的那样是'SolutionName.ClassData'。
要更改它,您需要更改列表框的DisplayMember属性 - listBox.DisplayMember = "Name"
对于asp.net列表框,它是DataTextField

答案 1 :(得分:0)

 <asp:DataList ID="dataList" runat="server"
        RepeatColumns="1"
        RepeatDirection="Horizontal"
        RepeatLayout="Table">
        <ItemTemplate>
            <table border="1" >
                <tr>
                    <td><asp:Label ID="Label1" runat="server" Text='<%# Eval("ID") %>' Width="50" /></td>
                    <td><asp:Label ID="Label2" runat="server" Text='<%# Eval("Name") %>' Width="20" /></td>
                    <td><asp:Label ID="Label3" runat="server" Text='<%# Eval("Age") %>' Width="200" /></td>
                    <td><asp:Label ID="Label4" runat="server" Text='<%# Eval("Time") %>' Width="200" /></td>
                </tr>
            </table>
        </ItemTemplate>
    </asp:DataList>