我有一个用户控件,用作更新学生记录的表单。此用户控件用于名为学生更新的页面中。更新成功后,我想禁用更新按钮。之后,如果用户更改了任何文本,则应该启用更新按钮。我正在尝试这个,但它不起作用。我的所有文本框autopost属性都为true。我可以禁用,但如果用户开始在文本框中输入新文本,我将无法再次启用它。我正在使用textbox.textchanged事件来实现这一点。
答案 0 :(得分:2)
Jquery方法:
<body>
<form id="form1" runat="server">
<div>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<asp:Button ID="Button1" runat="server" Text="Button" Enabled="false" />
</div>
</form>
<script src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-1.9.0.min.js" type="text/javascript"></script>
<script type="text/javascript">
$("#<%= TextBox1.ClientID %>").keyup(function () {
$("#<%= Button1.ClientID %>").attr("disabled", $(this).val() == "");
});
</script>
</body>
或者您可以在服务器端执行此操作:
<asp:textbox id="TextBox1" runat="server" autopostback="True" ontextchanged="TextBox1_TextChanged"></asp:textbox>
<asp:button id="Button1" runat="server" enabled="False" text="Button" />
protected void TextBox1_TextChanged(object sender, EventArgs e)
{
Button1.Enabled = !String.IsNullOrEmpty(TextBox1.Text);
}
答案 1 :(得分:1)
<script src="http://ajax.aspnetcdn.com/ajax/jquery/jquery-1.9.0.min.js" type="text/javascript"></script>