前端开发避坑-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

相关文章

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

CSS引入方式和选择符的讲解和运用小结

《CSS引入方式和选择符的讲解和运用小结》CSS即层叠样式表,是一种用于描述网页文档(如HTML或XML)外观和格式的样式表语言,它主要用于将网页内容的呈现(外观)和结构(内容)分离,从而实现... 目录一、前言二、css 是什么三、CSS 引入方式1、行内样式2、内部样式表3、链入外部样式表四、CSS 选

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Idea插件MybatisX失效的问题解决

《Idea插件MybatisX失效的问题解决》:本文主要介绍Idea插件MybatisX失效的问题解决,详细的介绍了4种问题的解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录一、重启idea或者卸载重装MyBATis插件(无需多言)二、检查.XML文件与.Java(该文件后缀Idea可能会隐藏

Nginx 访问 /root/下 403 Forbidden问题解决

《Nginx访问/root/下403Forbidden问题解决》在使用Nginx作为Web服务器时,可能会遇到403Forbidden错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录解决 Nginx 访问 /root/test/1.html 403 Forbidden 问题问题复现Ng

MySQL中的两阶段提交详解(2PC)

《MySQL中的两阶段提交详解(2PC)》:本文主要介绍MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录引言两阶段提交过程sync_binlog配置innodb_flush_log_at_trx_commit配置总结引言在Inn

Python的pip在命令行无法使用问题的解决方法

《Python的pip在命令行无法使用问题的解决方法》PIP是通用的Python包管理工具,提供了对Python包的查找、下载、安装、卸载、更新等功能,安装诸如Pygame、Pymysql等Pyt... 目录前言一. pip是什么?二. 为什么无法使用?1. 当我们在命令行输入指令并回车时,一般主要是出现以

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

C++迭代器失效的避坑指南

《C++迭代器失效的避坑指南》在C++中,迭代器(iterator)是一种类似指针的对象,用于遍历STL容器(如vector、list、map等),迭代器失效是指在对容器进行某些操作后... 目录1. 什么是迭代器失效?2. 哪些操作会导致迭代器失效?2.1 vector 的插入操作(push_back,