【发布时间】:2013-12-19 05:34:56
【问题描述】:
但是,我有以下代码可以正常工作;当我单击删除按钮时,事件会触发,但更改未显示在 PostBack 上。这显然与 PostBack 管理有关。有人有什么建议吗?
namespace WebApplication1
{
public partial class questiondetails : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
LoadControls();
}
}
void Edit_Click(object sender, ImageClickEventArgs e)
{
ImageButton editbut = sender as ImageButton;
string cName = editbut.ID;
string rID = cName.Remove(0, 5);
Response.Write(Request.Form["entity_" + rID]);
Response.Write(Request.Form["dollar_" + rID]);
}
void Delete_Click(object sender, ImageClickEventArgs e)
{
var delbut = (ImageButton)sender;
string cName = delbut.ID;
string rID = cName.Remove(0, 7);
string MyParams = "@RowID=" + rID;
iservices.DataAccessWebService WS = new iservices.DataAccessWebService();
WS.ExecuteDatasetStoredProcedure(ConfigurationManager.AppSettings["SecurityDataAccess"], "iweb_sp_custom_coi_Question_Delete", MyParams.ToString());
LoadControls();
Response.Write("dome");
}
protected void LoadControls()
{
//Construct paramters from Querystring
StringBuilder MyParams = new StringBuilder();
MyParams.Append("@Term=2013,@ProjectCode=a12345,@ID=123,@CategoryCode=CONSULTANCIES");
//Count Answered questions
iservices.DataAccessWebService WS = new iservices.DataAccessWebService();
DataSet MyAnswers = WS.ExecuteDatasetStoredProcedure(ConfigurationManager.AppSettings["SecurityDataAccess"], "iweb_sp_custom_coi_SelectCurrentQuestion", MyParams.ToString());
foreach (DataTable dt in MyAnswers.Tables)
{
int rc = 0;
foreach (DataRow dr in dt.Rows)
{
//Generate unique controls from DS
TextBox tbx = new TextBox();
tbx.ID = "entity_" + dr["rowID"].ToString();
tbx.Text = dr["EntityName"].ToString();
tbx.Width = 200;
DropDownList DollarRange = new DropDownList();
DollarRange.Items.Add("Select Dollar Amount");
DollarRange.Items.Add("Up to $1,000");
DollarRange.Items.Add("$1,001 - 5,000");
DollarRange.Items.Add("$5,001 - $10,000");
DollarRange.Items.Add("$10,001 - $50,000");
DollarRange.Items.Add("$50,001 - or more");
DollarRange.ID = "dollar_" + dr["rowID"].ToString();
DollarRange.SelectedValue = dr["DollarRange"].ToString();
ImageButton Delete = new ImageButton();
Delete.ImageUrl = "delete.png";
Delete.ID = "delete_" + dr["rowID"].ToString();
Delete.Click += Delete_Click;
ImageButton Edit = new ImageButton();
Edit.ImageUrl = "edit.png";
Edit.ID = "edit_" + dr["rowID"].ToString();
Edit.Click += Edit_Click;
//Append controls to placeholder
DataZone.Controls.Add(new LiteralControl((rc % 2 == 0) ? "<tr><td bgcolor='#f1f0e7'>" : "<tr><td>"));
DataZone.Controls.Add(tbx);
DataZone.Controls.Add(new LiteralControl((rc % 2 == 0) ? "</td><td bgcolor='#f1f0e7'>" : "</td><td>"));
DataZone.Controls.Add(DollarRange);
DataZone.Controls.Add(new LiteralControl((rc % 2 == 0) ? "</td><td bgcolor='#f1f0e7'>" : "</td><td>"));
DataZone.Controls.Add(Delete);
DataZone.Controls.Add(Edit);
DataZone.Controls.Add(new LiteralControl("</td></tr>"));
rc++;
}
}
}
}
}
【问题讨论】:
-
是的,没有数据返回。我检查了数据库,信息仍然存在。如果我通过刷新再次加载页面,我的两个数据都会重新出现。
-
当您在 UI 上单击 Delete_Click 方法时会触发它吗?
-
没有。我将代码移到 page_load 部分,它会触发并删除记录,但我的数据在处理修改后的数据之前显示,所以我看到的是旧结果。