今天在一个ASP.NET项目中,有个页面提交时,因为数据量比较大,页面刷新比较慢,有的用户多次点击提交按钮。导致有多条记录插入到数据。
就想把按钮做成只能点击一次,不能再次点击的效果。在网上查找按钮的onclientclick 和验证控件的冲突的问题(唉~~,以前看过没有记住o(╯□╰)o)时,无意看到有人写过这样的只能点击一次的按钮。
有两个假设前提:
- Button必须是button类型,不能使submit类型
- 如果我们使用验证,javascript可以使用。
.aspx 页面:
注意黑体字噢
.aspx.cs
protected void Button1_Click(object sender, EventArgs e)
{
System.Threading.Thread.Sleep(1000);
Label1.Text = DateTime.Now.ToString();
}
.js
if (btn.getAttribute('type') == 'button')
{
// The msg attibute is absolutely optional
// msg will be the text of the button while it's disabled
if (!msg || (msg='undefined')) { msg = 'Loading...'; }
btn.value = msg;
// The magic :D
btn.disabled = true;
}
return true;
}
代码中的注释都是比较简单的英文,就没有翻译(*^__^*) ……
代码引用自:http://weblogs.asp.net/javinavarro/archive/2007/11/15/clickonce-button.aspx