禁用 asp.net 文本框在启用和更改文本后返回旧值
本文关键字:文本 返回 启用 net asp 禁用 | 更新日期: 2023-09-27 17:55:55
我的问题是我有一个asp文本框,它有一个值(文本)但被禁用(启用="假")
单击(编辑)按钮后,它变为启用(启用="true"),因此我可以更改文本
--> 更改文本后点击(保存)按钮,取旧值(text)之前编辑并保存它而不是新的。.
只读属性也会发生此问题。
我被困在这个..所以任何帮助我将不胜感激。
<telerik:RadAjaxPanel ID="AjaxPanel1" runat="server" LoadingPanelID="LoadingPanelTelerik">
<tr>
<td align="right" valign="top">
<asp:TextBox runat="server" ID="Email" CssClass="InputForm" />
</td>
</tr>
<tr>
<td align="center" colspan="2" valign="bottom">
<asp:Button ID="UpdateButton" runat="server" Text="تـعــديـل" OnClick="Enable_Info" Font-Size="Large" />
<asp:Button ID="CancelButton" runat="server" Text="إلـغـاء" OnClick="Cancel_Info" Font-Size="Large" Visible="false"/>
</td>
</tr>
</telerik:RadAjaxPanel>
以下是 C# 代码(无需编写 SQL 连接):
protected void Page_Load(object sender, EventArgs e)
{
Email.Text = myDataTable.Rows[0][2].ToString();
Email.DataBind();
Email.Enabled = false;
}
protected void Enable_Info(object sender, EventArgs e)
{
if (UpdateButton.Text == "تـعــديـل")
{
Email.Enabled = true;
UpdateButton.Text = "حــفـظ";
CancelButton.Visible = true;
}
else if (UpdateButton.Text == "حــفـظ")
{
AjaxPanel1.EnableAJAX = false;
int CustomerId = System.Convert.ToInt32(Request.Cookies["User"]["CustomerId"]);
string email = Email.Text;
SqlConnection conn = new SqlConnection(ArabShoppingConfiguration.DbConnectionString);
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandType = CommandType.Text;
cmd.CommandText = "update Customer set Email = '" + email + "' where Id = '" + CustomerId + "'";
try
{
conn.Open();
cmd.ExecuteScalar();
}
catch (Exception ex)
{
throw ex;
}
finally
{
conn.Close();
}
}
}
protected void Cancel_Info(object sender, EventArgs e)
{
Email.Enabled = false;
UpdateButton.Text = "تـعــديـل";
CancelButton.Visible = false;
}
好的,
所以问题是您在页面加载中设置了 Email.Text,每次页面加载时都会运行以包含所有回发。页面加载在 Enable_Info 方法之前触发,因此每次都会将文本更改回来。您需要做的就是修改您的page_load代码,使其仅在页面首次加载时运行,而不是在回发时运行:
protected void Page_Load(object sender, EventArgs e)
{
if(!Page.IsPostBack)
{
Email.Text = myDataTable.Rows[0][2].ToString();
Email.DataBind();
Email.Enabled = false;
}
}