单击任何动态生成的按钮控件确实会调用b_Click方法并删除给定用户,但是,在删除页面时不会重新加载“新”用户列表。
protected void Page_Load(object sender, EventArgs e)
{
DbDB db = new DbDB();
List<User> users = db.GetUsers().ExecuteTypedList<User>();
foreach (User u in users)
{
Button b = new Button();
b.Text = u.FirstName;
b.Click += new EventHandler(b_Click);
PlaceHolder1.Controls.Add(b);
}
}
}
void b_Click(object sender, EventArgs e)
{
Button b = (Button)sender;
DbDB.User.Delete(x => x.FirstName == b.Text);
}
答案 0 :(得分:2)
protected void Page_Load(object sender, EventArgs e) {
LoadUsers();
}
void b_Click(object sender, EventArgs e) {
Button button = (Button)sender;
string firstName = button.CommandArgument;
DbDB.User.Delete(x => x.FirstName == firstName);
PlaceHolder1.Controls.Remove(button);
}
void LoadUsers() {
DbDB db = new DbDB();
List<User> users = db.GetUsers().ExecuteTypedList<User>();
foreach (User user in Users) {
Button button = new Button();
button.CommandArgument = user.FirstName; // normally the user "id" to identify the user.
button.Text = user.FirstName;
button.Click += new EventHandler(b_Click);
PlaceHolder1.Controls.Add(button);
}
}
答案 1 :(得分:1)
这是因为在Click事件之前调用了Page_Load事件,因此当您在Page_Load中从数据库中检索用户列表时,用户仍然在那里。作为一种快速解决方案,您可以将代码从Page_Load移动到PreRender事件。
有关页面生命周期的更多信息,请查看此链接:http://msdn.microsoft.com/en-us/library/ms178472.aspx
答案 2 :(得分:0)
您不需要为每个回复选择用户。此外,您无需在运行时为此创建控件。
以下是另一种方式。
<asp:Repeater runat="server" ID="myRepeater">
<ItemTemplate>
<asp:Button runat="server" OnClick="Button_Click" Text='<%# DataBinder.Eval(Container.DataItem, "FirstName") %>' />
</ItemTemplate>
</asp:Repeater>
protected void Page_Load(object sender, EventArgs e)
{
if (!this.IsPostBack)
{
// load users
myRepeater.DataSource = users;
myRepeater.DataBind();
}
}
protected void Button_Click(object sender, EventArgs e)
{
// delete user
Button button = sender as Button;
button.Visible = false;
}
答案 3 :(得分:0)
将你的page_load正文写在
中if(!IsPostBack)
{
....
}
这应该有效。