javascript判断return后依旧将表单提交到后端问题

这次在写提交表单时候忽然遇到了这个问题,在<script type="text/javascript"></script>标签中判断return后,前端依旧将数据提交到了后端,最后发现是漏了type属性。下面用一段简单的稍微详细的描述一下遇到的问题。

示例错误代码:

<html>
  <head>
    <title>注册</title>
  </head>
  <body>
    <script type="text/javascript">
        function register(){
            if(fr.name.value == ""){
                alert("姓名不能为空");
                return;
            }else if(fr.password.value == ""){
                alert("密码不能为空");
                return;
            }else if(fr.password2.value == ""){
                alert("请确认密码");
                return;
            }else if(fr.password.value != fr.password2.value){
                alert("两次密码输入不一致");
                return;
            }
            fr.submit();
        }
    </script>
    <form action="registerpage.jsp" name="fr" method="post">
        姓名:&emsp;&emsp;<input name="name" type="text"><br>
        密码:&emsp;&emsp;<input type="password" name="password"><br>
         确认密码:<input type="password" name="password2"><br>
        <button onclick="register()">提交</button>
    </form>
  </body>
</html>

 

当任意框为空时,js应当弹出警告窗口,关闭后不应提交至后端。而上面的代码在return后依旧会将表单内容提交给后端处理。

 

错误原因很简单,虽然提交按钮用了button标签,但是漏掉type标签,导致默认将表单内容提交至后端,所以只需要加上 type="button" 就可以解决了。当然如果使用input标签可能不会犯这个低级错误了。

 

修改后代码:

<html>
  <head>
    <title>注册</title>
  </head>
  <body>
    <script type="text/javascript">
        function register(){
            if(fr.name.value == ""){
                alert("姓名不能为空");
                return;
            }else if(fr.password.value == ""){
                alert("密码不能为空");
                return;
            }else if(fr.password2.value == ""){
                alert("请确认密码");
                return;
            }else if(fr.password.value != fr.password2.value){
                alert("两次密码输入不一致");
                return;
            }
            fr.submit();
        }
    </script>
    <form action="registerpage.jsp" name="fr" method="post">
        姓名:&emsp;&emsp;<input name="name" type="text"><br>
        密码:&emsp;&emsp;<input type="password" name="password"><br>
         确认密码:<input type="password" name="password2"><br>
        <button type="button" onclick="register()">提交</button>
    </form>
  </body>
</html>
View Code
posted @ 2020-02-13 20:52  Maolic  阅读(374)  评论(0编辑  收藏  举报