【发布时间】:2011-09-08 22:21:37
【问题描述】:
在下面的代码中,单击按钮后文本框的值没有被清除。
默认.aspx
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
<br />
<asp:Timer ID="Timer1" runat="server" ontick="Timer1_Tick" Interval="20">
</asp:Timer>
<br />
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<Triggers>
<asp:AsyncPostBackTrigger controlid="Timer1" eventname="Tick" />
</Triggers>
<ContentTemplate>
<asp:Label ID="Label1" runat="server" Text="Label"></asp:Label>
<asp:Repeater ID="Shout_Box" runat="server">
<ItemTemplate>
<%# DataBinder.Eval(Container.DataItem, "Message") %>
</ItemTemplate>
</asp:Repeater>
<asp:Button ID="Button1" runat="server" Text="Button" onclick="Button1_Click" />
</ContentTemplate>
</asp:UpdatePanel>
<asp:TextBox ID="TextBox1" runat="server">
</asp:TextBox>
</form>
</body>
</html>
用于按钮单击的 C# 代码。
protected void Button1_Click(object sender, EventArgs e)
{
string MyConString = "DRIVER={MySQL ODBC 3.51 Driver};" + "SERVER=localhost;" + "DATABASE=repeater;" + "UID=root;" + "PASSWORD=********;" + "OPTION=3";
OdbcConnection MyConnection = new OdbcConnection(MyConString);
OdbcCommand cmd = new OdbcCommand("INSERT INTO table1(message)VALUES(?)", MyConnection);
cmd.Parameters.Add("@email", OdbcType.VarChar, 255).Value = TextBox1.Text;
MyConnection.Open();
cmd.ExecuteNonQuery();
MyConnection.Close();
TextBox1.Text = "";
}
我尝试在上面添加一行TextBox1.Text = ""; 以清除文本,但没有用。
请不要要求我将 Button 保留在 updatepanel 标记之外。我需要在不发回页面的情况下完成活动。
如果文本框在里面由于定时器触发了 20 秒,文本框太闪烁并且不允许编辑。简单地说TextBox令人耳目一新,甚至不允许添加任何文字。
我不想将此扩展到 JavaScript 和其他以清除文本框中的值。谁能告诉我如何使用 C# 清除文本框的值。
【问题讨论】: