我有一个数据列表,我想重复项目并使用自动(行交替)颜色为我正在处理的应用程序。我正在尝试在项目模板上方添加标题模板,如此。
<table>
<asp:DataList ID="DataList1" runat="server" CellPadding="4" DataKeyField="num" DataSourceID="SqlDataSource1" ForeColor="#333333" OnItemDataBound="DataList1_ItemDataBound">
<AlternatingItemStyle BackColor="White" />
<FooterStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
<HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
<ItemStyle BackColor="#EFF3FB" />
<HeaderTemplate>
<tr>
<th>Item Name</th>
<th>Item Type</th>
<th>Item Price</th>
<th>End(s) In</th>
</tr>
</HeaderTemplate>
<ItemTemplate>
<tr>
<td><a class="rolls2" href="ItemView.aspx?ItemName=<%# Eval("ItemName") %>&num=<%# Eval("num") %>"><%# Eval("ItemName") %></a></td>
<td><%# Eval("ItemType")%></td>
<td>$ <%# Eval("ItemPrice")%></td>
<td><asp:Label ID="lblExp" Text='<%# Bind("CreateDate") %>' runat="server" /></td>
</tr>
</ItemTemplate>
<SelectedItemStyle BackColor="#D1DDF1" Font-Bold="True" ForeColor="#333333" />
</asp:DataList>
<table>
当我运行此代码时,我得到一个未设置为对象引用的对象,它指向lblExp
。
如果我删除标题,项目运行成功。还有另一种方法可以简单地在表格中添加标题吗?
答案 0 :(得分:2)
如果没有看到您的代码,很难对此进行诊断,但我猜您的DataList1_ItemDataBound
方法正在尝试查找lblExp
中的e.Item
控件而不检查e.Item.ItemType
首先
此事件将针对列表中的每个项目(包括标题)引发,并且标题不包含名为lblExp
的控件。
在处理项目之前,您需要检查ItemType
:
protected void DataList1_ItemDataBound(object sender, DataListItemEventArgs e)
{
switch (e.Item.ItemType)
{
case ListItemType.Item:
case ListItemType.AlternatingItem:
case ListItemType.SelectedItem:
case ListItemType.EditItem:
{
Label lblExp = (Label)e.Item.FindControl("lblExp");
...
}
}
}