我正在建立一个网站,人们在退出购物车之前(并转移到付款iframe)可以选择要从购物车列表中删除哪些商品。购物卡的结果列在Repeater控件中。 Repeater中有一个Button,用于从数据库中删除记录(使用LINQ to SQL来执行此操作。)
问题是当我点击按钮时,ItemCommand事件不会触发。我试过了response.write(test)
但它仍然行不通。
就好像转发器无法与命令交互。它确实渲染了结果。
<asp:Repeater ID="RepeaterKoshnichka"
runat="server" OnItemCommand="RepeaterKoshnichka_ItemCommand"
DataSourceID="LinqDataSource1">
<ItemTemplate>
<tr>
<td background="images/message-bar.gif">
<div class="message_head" style="float:left"><cite>Производ: <asp:Label ID="lblProizvod" CssClass="red_tx" Text='<%# Eval("Proizvod") %>' runat="server"></asp:Label> / Тип на Претплата: <asp:Label ID="lblPretplata" runat="server" Text='<%# Eval("Tip") %>' CssClass="red_tx"></asp:Label></cite></div>
<div class="message_head" style="float:right"><cite>Цена: <asp:Label ID="lblCena" CssClass="red_tx" Text='<%# Eval("Cena") %>' runat="server"></asp:Label>
<asp:Button ID="Button2" CssClass="main_tx" CommandName="Delete" CommandArgument='<%# Eval("NDetID") %>' runat="server" Text="Отстрани" /></cite>
</div>
</td>
</tr>
</ItemTemplate>
</asp:Repeater>
protected void RepeaterKoshnichka_ItemCommand(object source, RepeaterCommandEventArgs e)
{
if (e.CommandName == "Delete")
{
if (Request.Form[e.CommandArgument.ToString()] != null)
{
if (Page.User.Identity.IsAuthenticated)
{
var nar = new DataClasses1DataContext();
Guid detnar = new Guid(e.CommandArgument.ToString());
var query = from c in nar.Naracka_Dets
where c.NDetID == detnar
select c;
foreach (var c in query)
{
nar.Naracka_Dets.DeleteOnSubmit(c);
}
nar.SubmitChanges();
lblSuma.Text = ((Button)e.CommandSource).ToString();
}
}
}
}
答案 0 :(得分:2)
对于您正在处理的内容,<asp:GridView>
可能是更好的服务器控件。
顺便说一下,考虑对代码进行一些小改动。为了使其更具可读性,请将您的3个条件合并为一个if
:
if (e.CommandName == "Delete" &&
Request.Form[e.CommandArgument.ToString()] != null &&
Page.User.Identity.IsAuthenticated)
{
//delete things.
}
答案 1 :(得分:1)
如果您不想使用Repeater
,则应切换到DataGrid
并使用ButtonColumn获取此功能 - 这样可以让您更轻松地处理Item事件。