JS中如何防止表单重复提交问题


在登录页面html中写如下代码

<script type="text/javascript">
        var issubmit=false;
        function dosubmit(){
            if(issubmit==false){
                issubmit=true;
                return true;
            }else{
                return false;
            }
            
        }
    </script>
  </head>
  
  <body>
      <form action="/Day07/FormSubmit" method="get" onsubmit="return dosubmit()">
          用户名:<input type="text" name="usrname">
          <br><input type="submit" value="提交">
      </form>
  </body>

重点是这个JS语句 定义了一个方法 共用一个Flag标记 进行验证 如果已经提交过,就返回一个false给onsubmit这个数据

如果没有提交过 将标记设置为true 并且返回一个ture 给onsubmit 让其提交一次数据 这是js防止表单重复提交 应对的是传输数据

时网络延时 而用户多次提交数据 造成的问题

当然还有一种思路 可以设置提交按钮在提交一次之后不可用 也就是变为灰色 那么该怎么做勒

<script type="text/javascript">
        function dosubmit(){
            var input=document.getElementById("submit");
            input.disabled='diabled';
            return ture;
        }
</script>

<form action="/Day07/FormSubmit" method="get" onsubmit="dosubmit()" ><!-- onsubmit="return dosubmit()" -->
          用户名:<input type="text" name="usrname">
          <br><input id="submit" type="submit" value="提交">
</form>

当然这种方式只能做到提交 并且按钮不可用 但是无法防止比如用户修改提交页面 或者用户刷新 或者后退等重复操作

只能做到减少服务器接受数据并检查的频率 但是这样依旧有利于减少服务器的工作量

 

  


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM