欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

JQuery脚本-通过禁用按钮防止表单重复提交

程序员文章站 2022-07-13 12:00:17
...
<script type="text/javascript">
/*
jquer 脚本,避免重复提交
隐藏点击的submit,后在他之后插入同名button伪装成被隐藏的submit
最后禁用全部可见的submit和button
最终效果:点击按钮提交表单后,点击后退按钮,返回提交表单页面,提交按钮已被禁用
注:此方法毕竟在客户端处理,防君子不防小人
*/
    $(document).ready(function() {
        $(":submit").click(function() {
            $(this).hide();
            $(this).after("<input type=\"button\" value=\"" + $(this).val() + "\">");
            $(":submit:visible").attr("disabled", "disabled");
            $(":button:visible").attr("disabled", "disabled");
            alert($(this).val());
        });
    });
</script>

******************************************************************************************************

这里提供两种不同情况下的阻止重复点击解决方案。
1.按钮BUTTON类
2.<a>标签类

对于第一类情况,button有一个属性是disabled控制其是否可以点击,看代码:

<input type="button" value="Click"id="subBtn"/>
<script type="text/javascript">
function myFunc(){
    //code
   //执行某段代码后可选择移除disabled属性,让button可以再次被点击
    $("#subBtn").removeAttr("disabled");
}
$("#subBtn").click(function(){
    //让button无法再次点击
   $(this).attr("disabled","disabled");
    //执行其它代码,比如提交事件等
    myFunc();
});
</script>

第二类情况,可以使用按钮或链接的click事件来执行预期的单击动作,然后将事件处理重定向,以阻止其余的点击。

<a href="javascript:;" οnclick="return funcOne();">点击</a>
<scripttype="text/javascript">
function funcOne(){
    //点击一次后把funcTwo赋给funcOne,funcTwo是一个什么也不执行的函数,因此再次点击不执行任何操作
    funcOne=funcTwo;
	alert("Clickthe button!");
    return false;
}
function funcTwo(){
    return false;
}
</script>