<asp:DataGrid id="DataGrid1" runat="server">
<Columns>
<asp:BoundColumn DataField="id" DataFormatString="{0}" Visible="False"></asp:BoundColumn>
<asp:ButtonColumn CommandName="del" ButtonType="PushButton" DataTextField="id" DataTextFormatString="删除{0}" ></asp:ButtonColumn>
</Columns>
</asp:DataGrid>
private void Page_Load(object sender, System.EventArgs e)
{
string IsBuy = this.Request.QueryString.Get("IsBuy");
string username = (string)Session["username"];
if(!this.IsPostBack){
this.DataGrid1.DataSource = ProductManager.getProductListByOwnerName(username,IsBuy);
this.DataGrid1.DataBind();
}
// 在此处放置用户代码以初始化页面
}
#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}
/// <summary>
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
/// </summary>
private void InitializeComponent()
{
this.DataGrid1.ItemCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.ExcuteItemCommand);
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private void ExcuteItemCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
{
if(e.CommandName=="del"){
ProductManager.DeleteProduct(e.Item.Cells[0].Text);
this.response.redirect(...);
}
}
//基本的思路就是先构建一个不显示的列,
//根据这一列得到当前item的文本内容
//然后进行删除