Validator验证Ajax提交表单的方法
2023-09-14 08:57:44 时间
当我们在一些稍微复杂的业务时,可能会遇到需要多个表单form在同一个页面的情况,但是提交一个表单以后不想页面刷新或者跳转,那么我们考虑到的就是Ajax提交表单,那么如何让Jquery的validator插件也可以对异步提交的表单进行验证呢?我们继续往下看。
在这里,我就用网络上的一个例子来说明好了。
下面是一个比较常见的jquery .ajax提交表单的写法
- $("#submitButton").click(function(){
- //序列化表单
- var param = $("#leaveSave").serialize();
- $.ajax({
- url : "leaveSave.action",
- type : "post",
- dataType : "json",
- data: param,
- success : function(result) {
- if(result=='success') {
- location.href='allRequisitionList.action';
- } else if(result.startWith("error_")){
- $("#errorMessage").html(result.substring(6));
- } else {
- //返回的结果转换成JSON数据
- var jsonObj = eval('('+result+')');
- startTime = $("#startdate").val();
- endTime = $("#enddate").val();
- hour = jsonObj.hour;
- reason = jsonObj.reason;
- replaceDom(startTime,endTime,hour,reason);
- }
- }
- });
- });
如果想用ajax提交表单,还想用jquery的validate进行验证,那么可以这样解决:表单还是正常编写的表单内容,type还是submit类型,只不过在validate验证通过后的方法中使用ajax提交表单
- $("#saveWorkExtra").validate({
- onsubmit:true,// 是否在提交是验证
- onfocusout:false,// 是否在获取焦点时验证
- onkeyup :false,// 是否在敲击键盘时验证
- rules: {
- ....
- },
- messages:{
- ....
- },
- submitHandler: function(form) { //通过之后回调
- var param = $("#saveToWorkExtra").serialize();
- $.ajax({
- url : "workExtraChange.action",
- type : "post",
- dataType : "json",
- data: param,
- success : function(result) {
- if(result=='success') {
- location.href='allRequisitionList.action';
- } else {
- var jsonObj = eval('('+result+')');
- }
- }
- });
- },
- invalidHandler: function(form, validator) { //不通过回调
- return false;
- }
- });
相关文章
- JS - 局部方法改变全局变量的值
- java实现遍历树形菜单方法——HibernateUtil实现
- video视频内容填充整个播放空间方法
- jquery中页面Ajax方法$.load的功能
- web开发过程中经常用到的一些公共方法及操作
- $.ajax()方法详解
- Date对象常用方法
- 102、xutils post和get请求上传参数的添加方法是分开的
- 前端调错(一)---ajax返回数据成功,却进入error方法
- 怎么用命令激活win10教育版|win10教育版命令激活方法
- Atitit 高并发 性能指标 与压测工具 压测方法 目录 1. 性能的几个指标1 1.1. 主要是响应时间(Response time)1 1.2. 2.吞吐量(Throughput)1 1
- 前后端交互模式大总结 艾提拉 总结 attilax总结 目录 1. 通过ajax ajax就是js的网络api 完全解耦合 推荐1 1.1. Query Ajax 操作函数1 1.2. 服务
- ajax不执行异步方法,直接执行error回调函数
- JS直接调用C#后台方法(ajax调用)
- uitextField单词的方法和抖动的限制
- 在Visual Stdio 2012中编译执行JM18.6的方法
- 一般来说,主方法main()结束的时候线程结束
- PHP允许AJAX跨域请求的两种方法
- 快速下载windows10/8/7镜像方法--能达到10M/S
- arthas使用示例:stack输出当前方法被调用的路径