当我点击 LinkButton 时,它没有调用函数 "LinkButton_Click"
When I click on the LinkButton, it doesn't call the function "LinkButton_Click"
LinkButton我需要在后端做,所以我无法在前端使用OnClientClick。知道如何解决吗?
protected void GridView_RowDataBound(object sender, GridViewRowEventArgs e)
{
TableCell tc = new TableCell();
if (e.Row.RowType == DataControlRowType.Header)
{
e.Row.Cells[0].Text = "Staff ID";
e.Row.Cells[1].Text = "Staff Name";
e.Row.Cells[2].Text = "Position";
e.Row.Cells[3].Text = "Status";
e.Row.Cells[4].Text = "Phone";
e.Row.Cells[5].Text = "Email";
//Add an addition column, else cant add linkbutton at the last column
e.Row.Controls.Add(tc);
}
else if (e.Row.RowType == DataControlRowType.DataRow)
{
//add linkbutton at every last column
e.Row.Controls.Add(tc);
LinkButton link = new LinkButton();
link.ID = "lbEdit";
link.Text = "Edit";
e.Row.Cells[6].Controls.Add(link);
link.Click += new EventHandler(LinkButton_Click);
if (e.Row.Cells[3].Text == "Inactive")
{
e.Row.Cells[3].CssClass = "redCell";
}
}
}
这是LinkButton_Click函数
protected void LinkButton_Click(object sender, EventArgs e)
{
Response.Write("<script>alert('It works!')</script>");
Response.Redirect("~/product.aspx");
}
或者我在哪里可以粘贴我的“link.Click += new EventHandler(LinkButton_Click);”?
这是
<asp:GridView CssClass="GridView" ID="staffList" AutoGenerateColumns="true" runat="server" onrowdatabound="GridView_RowDataBound">
</asp:GridView>
整个后端代码
public partial class staff : System.Web.UI.Page
{
string sqlConn = Convert.ToString(ConfigurationManager.AppSettings["connectionString"]);
//LinkButton link = new LinkButton();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
BindGridView();
}
}
private void BindGridView()
{
MySqlConnection conn = new MySqlConnection(sqlConn);
string sql = "SELECT * from Staff";
MySqlCommand cmd = new MySqlCommand(sql, conn);
MySqlDataAdapter sda = new MySqlDataAdapter(cmd);
DataTable dt = new DataTable();
sda.Fill(dt);
staffList.DataSource = dt;
staffList.DataBind();
}
protected void GridView_RowDataBound(object sender, GridViewRowEventArgs e)
{
TableCell tc = new TableCell();
LinkButton link = new LinkButton();
if (e.Row.RowType == DataControlRowType.Header)
{
e.Row.Cells[0].Text = "Staff ID";
e.Row.Cells[1].Text = "Staff Name";
e.Row.Cells[2].Text = "Position";
e.Row.Cells[3].Text = "Status";
e.Row.Cells[4].Text = "Phone";
e.Row.Cells[5].Text = "Email";
//Add an addition column, else cant add linkbutton at the last column
e.Row.Controls.Add(tc);
}
else if (e.Row.RowType == DataControlRowType.DataRow)
{
//add linkbutton at every last column
e.Row.Controls.Add(tc);
link.ID = "lbEdit";
link.Text = "Edit";
e.Row.Cells[6].Controls.Add(link);
link.Click += new EventHandler(LinkButton_Click);
//maybe can create a for loop at here to store all data
if (e.Row.Cells[3].Text == "Inactive")
{
e.Row.Cells[3].CssClass = "redCell";
}
}
}
protected void LinkButton_Click(object sender, EventArgs e)
{
Response.Write("<script>alert('It works!')</script>");
Response.Redirect("~/product.aspx");
}
}
当您单击该按钮时,将发生 PostBack 并且 Gridview 绑定以及按钮链接将丢失。下面将 gridView.DataSource 保存到会话中。请注意 if (!IsPostPack) 已删除:
protected void Page_Load(object sender, EventArgs e)
{
if (Session["gvDS"] != null)
{
GridView1.DataSource = Session["gvDS"];
GridView1.DataBind();
}
else
BindGridView();
}
private void BindGridView()
{
MySqlConnection conn = new MySqlConnection(sqlConn);
string sql = "SELECT * from Staff";
MySqlCommand cmd = new MySqlCommand(sql, conn);
MySqlDataAdapter sda = new MySqlDataAdapter(cmd);
DataTable dt = new DataTable();
sda.Fill(dt);
staffList.DataSource = dt;
staffList.DataBind();
Session["gvDS"] = GridView1.DataSource; // save into session
}
LinkButton我需要在后端做,所以我无法在前端使用OnClientClick。知道如何解决吗?
protected void GridView_RowDataBound(object sender, GridViewRowEventArgs e)
{
TableCell tc = new TableCell();
if (e.Row.RowType == DataControlRowType.Header)
{
e.Row.Cells[0].Text = "Staff ID";
e.Row.Cells[1].Text = "Staff Name";
e.Row.Cells[2].Text = "Position";
e.Row.Cells[3].Text = "Status";
e.Row.Cells[4].Text = "Phone";
e.Row.Cells[5].Text = "Email";
//Add an addition column, else cant add linkbutton at the last column
e.Row.Controls.Add(tc);
}
else if (e.Row.RowType == DataControlRowType.DataRow)
{
//add linkbutton at every last column
e.Row.Controls.Add(tc);
LinkButton link = new LinkButton();
link.ID = "lbEdit";
link.Text = "Edit";
e.Row.Cells[6].Controls.Add(link);
link.Click += new EventHandler(LinkButton_Click);
if (e.Row.Cells[3].Text == "Inactive")
{
e.Row.Cells[3].CssClass = "redCell";
}
}
}
这是LinkButton_Click函数
protected void LinkButton_Click(object sender, EventArgs e)
{
Response.Write("<script>alert('It works!')</script>");
Response.Redirect("~/product.aspx");
}
或者我在哪里可以粘贴我的“link.Click += new EventHandler(LinkButton_Click);”?
这是
<asp:GridView CssClass="GridView" ID="staffList" AutoGenerateColumns="true" runat="server" onrowdatabound="GridView_RowDataBound">
</asp:GridView>
整个后端代码
public partial class staff : System.Web.UI.Page
{
string sqlConn = Convert.ToString(ConfigurationManager.AppSettings["connectionString"]);
//LinkButton link = new LinkButton();
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
BindGridView();
}
}
private void BindGridView()
{
MySqlConnection conn = new MySqlConnection(sqlConn);
string sql = "SELECT * from Staff";
MySqlCommand cmd = new MySqlCommand(sql, conn);
MySqlDataAdapter sda = new MySqlDataAdapter(cmd);
DataTable dt = new DataTable();
sda.Fill(dt);
staffList.DataSource = dt;
staffList.DataBind();
}
protected void GridView_RowDataBound(object sender, GridViewRowEventArgs e)
{
TableCell tc = new TableCell();
LinkButton link = new LinkButton();
if (e.Row.RowType == DataControlRowType.Header)
{
e.Row.Cells[0].Text = "Staff ID";
e.Row.Cells[1].Text = "Staff Name";
e.Row.Cells[2].Text = "Position";
e.Row.Cells[3].Text = "Status";
e.Row.Cells[4].Text = "Phone";
e.Row.Cells[5].Text = "Email";
//Add an addition column, else cant add linkbutton at the last column
e.Row.Controls.Add(tc);
}
else if (e.Row.RowType == DataControlRowType.DataRow)
{
//add linkbutton at every last column
e.Row.Controls.Add(tc);
link.ID = "lbEdit";
link.Text = "Edit";
e.Row.Cells[6].Controls.Add(link);
link.Click += new EventHandler(LinkButton_Click);
//maybe can create a for loop at here to store all data
if (e.Row.Cells[3].Text == "Inactive")
{
e.Row.Cells[3].CssClass = "redCell";
}
}
}
protected void LinkButton_Click(object sender, EventArgs e)
{
Response.Write("<script>alert('It works!')</script>");
Response.Redirect("~/product.aspx");
}
}
当您单击该按钮时,将发生 PostBack 并且 Gridview 绑定以及按钮链接将丢失。下面将 gridView.DataSource 保存到会话中。请注意 if (!IsPostPack) 已删除:
protected void Page_Load(object sender, EventArgs e)
{
if (Session["gvDS"] != null)
{
GridView1.DataSource = Session["gvDS"];
GridView1.DataBind();
}
else
BindGridView();
}
private void BindGridView()
{
MySqlConnection conn = new MySqlConnection(sqlConn);
string sql = "SELECT * from Staff";
MySqlCommand cmd = new MySqlCommand(sql, conn);
MySqlDataAdapter sda = new MySqlDataAdapter(cmd);
DataTable dt = new DataTable();
sda.Fill(dt);
staffList.DataSource = dt;
staffList.DataBind();
Session["gvDS"] = GridView1.DataSource; // save into session
}