前端开发避坑-form表单action和submit提交与ajax异步提交冲突引起的故障解决

本文主要是介绍前端开发避坑-form表单action和submit提交与ajax异步提交冲突引起的故障解决,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前端开发避坑-form表单action和submit提交与ajax异步提交冲突引起的故障解决!

近期在开发网站前端的时候,始终出现2次请求。困扰了很久。查询了网上的解决办法。发现,根源是因为,我的form表单里增加了一个action。虽然里面是空的,但是依然会在点击submit格式的按钮时,触发一次请求。这就引起了一种怪异的现象。

虽然ajax执行了成功!数据库执行了追加数据操作。但是页面始终停留在当前地址。

非常怪异,实际上,大家去掉form表单内的action,改一下submit,改成button模式,就可以恢复正常了。


<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><title>用户注册-积德寺-菩提佛堂app-网页版</title><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta name="keywords" content="许愿祈福,祈福网站"/><meta name="description" content="欢迎注册菩提佛堂app账号信息,可以参加线上共修活动!"/><link th:href="@{/static/css/mycommon.css}" rel="stylesheet" type="text/css"><link th:href="@{/static/css/login.css}" rel="stylesheet" type="text/css"><script th:src="@{/static/js/jquery.js}"></script><style>.qifu_main {margin:10px auto;padding:14px;border: 1px solid #99CC00;border-radius: 8px;background: rgba(235, 179, 22, 0.8);text-align: center;font-size: 1.0em;width: 80%;height:auto;}.qifu_main .form_register {width: auto;height: auto;}.qifu_main p img{width: 80%;}.qifu_main .form_register .item {margin: 8px auto;padding-bottom: 12px;text-align: left;width: auto;height: auto;}.qifu_main .form_register  button {display: block;width: 100px;height: 30px;border-radius: 10px;background-color: #ffb100;font-size: 1.0em;color: #FFFFFF;margin: 5px auto;}.qifu_main .form_register .item select{width: 30%;height: 26px;}.qifu_main .form_register .item input{width: 100%;height: 26px;}.qifu_main .form_register .item .icon-input{display: inline-block;height: 30px;line-height: 30px;}.qifu_main .form_register .item label img{width: 30px;height: auto;}</style>
</head>
<body>
<div th:replace="header :: top"></div>
<!--开始注册-->
<div class="qifu_main"><p>欢迎注册会员</p><form  id="form_register" class="form_register"><div class="item"><label for="uname"><img th:src="@{/static/images/icon-lianhua.png}">名字:</label><input type="text" required id="uname" name="username" minlength="2" maxlength="10"  placeholder="您的名字不超过10个字"><span class="msg-default hidden" id="namespan">用户名长度最小为2,最大为10</span></div><div class="item"><label for="upassword"><img th:src="@{/static/images/icon-lianhua.png}">密码:</label><input type="password" required id="upassword" minlength="6" maxlength="10" name="password"   placeholder="请设置您的密码"><span class="msg-default hidden">密码长度在6到10位之间</span></div><div class="item"><label for="upwdconfirm"><img th:src="@{/static/images/icon-lianhua.png}">验证密码:</label><input type="password" required id="upwdconfirm" name="upwdconfirm" minlength="6" maxlength="10"  placeholder="请再次输入密码"><span class="msg-default hidden">密码长度在6到10位之间</span></div><div class="item"><label for="phone"><img th:src="@{/static/images/icon-lianhua.png}">手机:</label><input type="phone" required id="phone" name="phone" maxlength="11" pattern="(\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{4}|\d{3})-(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1})|(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1}))$" placeholder="请输入手机号码"><span class="msg-default hidden" id="phonespan">手机长度最大50位</span></div><div class="item"><label for="email"><img th:src="@{/static/images/icon-lianhua.png}">邮箱:</label><input type="email" required id="email" name="email" maxlength="100"  placeholder="请输入邮箱"><span class="msg-default hidden" id="emailspan">邮箱长度最大100位</span></div><div class="item"><button type="button" id="btnRegister" >提交</button>&nbsp;&nbsp;<button type="reset" >重置</button></div></form>
</div>
<!--结束注册-->
<div th:replace="footer :: footer"></div>
<script>/*1.对用户名进行验证*///当对象失去焦点触发验证流程uname.onblur = function(){if(this.validity.valueMissing){this.nextElementSibling.innerHTML = '用户名不能为空';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('用户名不能为空');}else if(this.validity.tooShort){this.nextElementSibling.innerHTML = '用户名不能少于2位';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('用户名不能少于2位');}else {this.nextElementSibling.innerHTML = '用户名格式正确';this.nextElementSibling.className = 'msg-success';this.setCustomValidity('');var data =$("#uname").val();if(!data){   //用户没有输入任何内容return;}/**发起异步GET请求,询问服务器用户名是否已经存在**/$.ajax({url:"../user/checkName",data:"username="+$("#uname").val(),type:"get",dataType:"json",success:function(obj){$("#namespan").html(obj.message);//显示服务器的响应信息if(obj.state==0){$("#namespan").attr("class","msg-error");}else{$("#namespan").attr("class","msg-success");}}});}}uname.onfocus = function(){this.nextElementSibling.innerHTML = '用户名长度在2到10位之间';this.nextElementSibling.className = 'msg-default';}upassword.onfocus = function(){this.nextElementSibling.innerHTML = '密码长度在6到10位之间';this.nextElementSibling.className = 'msg-default';}upassword.onblur = function(){if(this.validity.valueMissing){this.nextElementSibling.innerHTML = '密码不能为空';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('密码不能为空');}else if(this.validity.tooShort){this.nextElementSibling.innerHTML = '密码长度在尽量别少于6位';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('密码长度在尽量别少于6位');}else {this.nextElementSibling.innerHTML = '密码格式正确';this.nextElementSibling.className = 'msg-success';this.setCustomValidity('');}}upwdconfirm.onfocus = function(){this.nextElementSibling.innerHTML = '密码长度在6到10位之间';this.nextElementSibling.className = 'msg-default';}//当确认密码输入框失去焦点时触发验证。upwdconfirm.onblur = function(){if(this.validity.valueMissing){this.nextElementSibling.innerHTML = '密码不能为空';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('密码不能为空');}else if(this.validity.tooShort){this.nextElementSibling.innerHTML = '密码长度在尽量别少于6位';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('密码长度在尽量别少于6位');}else {this.nextElementSibling.innerHTML = '密码格式正确';this.nextElementSibling.className = 'msg-success';this.setCustomValidity('');var pwd1 =$("#upassword").val();var pwd2 =$("#upwdconfirm").val();if(pwd1!=pwd2){this.nextElementSibling.innerHTML = '两次输入密码不一致';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('密码长度在尽量别少于6位');}else{this.nextElementSibling.innerHTML = '两次输入密码一致';this.nextElementSibling.className = 'msg-success';this.setCustomValidity('');}}}/*3.对邮箱地址进行验证*/email.onblur = function(){if(this.validity.valueMissing){this.nextElementSibling.innerHTML = '邮箱不能为空';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('邮箱不能为空');}else if(this.validity.typeMismatch){this.nextElementSibling.innerHTML = '邮箱格式不正确';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('邮箱格式不正确');}else {this.nextElementSibling.innerHTML = '邮箱格式正确';this.nextElementSibling.className = 'msg-success';this.setCustomValidity('');var data =document.getElementById("email").value;if(!data){   //用户没有输入任何内容return;}/**发起异步GET请求,询问服务器邮箱是否已经存在**/$.ajax({url:"../user/checkEmail",data:"email="+$("#email").val(),type:"get",dataType:"json",success:function(obj){$("#emailspan").html(obj.message);if(obj.state==0){$("#emailspan").attr("class","msg-error");}else{$("#emailspan").attr("class","msg-success");}}});}}email.onfocus = function(){this.nextElementSibling.innerHTML = '请输入合法的邮箱地址';this.nextElementSibling.className = 'msg-default';}/*3.对手机号进行验证*/phone.onblur = function(){if(this.validity.valueMissing){this.nextElementSibling.innerHTML = '手机号不能为空';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('手机号不能为空');}else if(this.validity.patternMismatch){this.nextElementSibling.innerHTML = '手机号格式不正确';this.nextElementSibling.className = 'msg-error';this.setCustomValidity('手机号格式不正确');}else {this.nextElementSibling.innerHTML = '手机号格式正确';this.nextElementSibling.className = 'msg-success';this.setCustomValidity('');var data =document.getElementById("phone").value;if(!data){   //用户没有输入任何内容return;}/**发起异步GET请求,询问服务器用户名是否已经存在**/$.ajax({url:"../user/checkPhone",data:"phone="+$("#phone").val(),type:"get",dataType:"json",success:function(obj){$("#phonespan").html(obj.message);if(obj.state==0){$("#phonespan").attr("class","msg-error");}else{$("#phonespan").attr("class","msg-success");}}});}}phone.onfocus = function(){this.nextElementSibling.innerHTML = '请输入合法的手机号';this.nextElementSibling.className = 'msg-default';}
</script>
<script>$('#btnRegister').click(function(){var lengths=0;$('.item').each(function(){if($(this).find('span').hasClass('msg-success')){lengths++;}});//异步注册提交if(lengths==5){$.ajax({url:"../user/register",data:$("#form_register").serialize(),//相当于表单内的提交表单值集合。必须使用到nametype:"post",dataType:"json",success:function(obj){if(obj.state==0){console.log(obj.state)$("#namespan").html(obj.message)$("#namespan").attr("class","msg-error")}else if(obj.state==1){console.log(obj.state)window.location = "../user/showLogin"}},error:function (obj){$("#namespan").html(obj.message)$("#namespan").attr("class","msg-error")}});}})
</script>
</body>
</html>

如图所示,这个就是,我修改后的代码,里面button,之前是submit.form的内容页删掉了action.

这篇关于前端开发避坑-form表单action和submit提交与ajax异步提交冲突引起的故障解决的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/855672

相关文章

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

XML重复查询一条Sql语句的解决方法

《XML重复查询一条Sql语句的解决方法》文章分析了XML重复查询与日志失效问题,指出因DTO缺少@Data注解导致日志无法格式化、空指针风险及参数穿透,进而引发性能灾难,解决方案为在Controll... 目录一、核心问题:从SQL重复执行到日志失效二、根因剖析:DTO断裂引发的级联故障三、解决方案:修复

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)

HTML中meta标签的常见使用案例(示例详解)

《HTML中meta标签的常见使用案例(示例详解)》HTMLmeta标签用于提供文档元数据,涵盖字符编码、SEO优化、社交媒体集成、移动设备适配、浏览器控制及安全隐私设置,优化页面显示与搜索引擎索引... 目录html中meta标签的常见使用案例一、基础功能二、搜索引擎优化(seo)三、社交媒体集成四、移动

HTML input 标签示例详解

《HTMLinput标签示例详解》input标签主要用于接收用户的输入,随type属性值的不同,变换其具体功能,本文通过实例图文并茂的形式给大家介绍HTMLinput标签,感兴趣的朋友一... 目录通用属性输入框单行文本输入框 text密码输入框 password数字输入框 number电子邮件输入编程框