onsubmit校验表单时利用ajax的return false 无效问题

本文探讨了在使用Ajax进行表单验证时遇到的return false无效的问题,并详细解释了问题产生的原因,包括异步请求的特性及如何通过修改Ajax设置来解决此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前几天,在校验一个表单数据时用到ajax时,遇到 return false 无效问题。
Js代码
  1. /**  
  2.  * 表单提交校验  
  3.  **/  
  4. function onSubmit(){   
  5.     if($('#name').val().length<2){   
  6.         alert("名称请不少于两个汉字");   
  7.         return false;   
  8.     }   
  9.     var t = new Date().getTime();   
  10.     $.ajax({   
  11.         type: "POST",   
  12.         url: "/users/checkrepeat/",   
  13.       data: "name=" + $('#name').val() + "&time=" + t,   
  14.         success:function(res){   
  15.             if(res == 'exists'){   
  16.                 alert("名称已存在,请修改.");   
  17.                 return false;   
  18.             }   
  19.         }   
  20.     });   
  21. }  

问题原因:

 

1. ajax时return false 的function与onsubmit()不是同一个函数;

2. 在ajax执行时,async默认的设置值为true,这种情况为异步方式,就是说当ajax发送请求后,在等待server端返回的这个过程中,前台会继续 执行ajax块后面的脚本,直到server端返回正确的结果才会去执行success,也就是说这时候执行的是两个线程,ajax块发出请求后一个线程 和ajax块后面的脚本(另一个线程)。

 

修改后的代码:

Js代码
  1. /**  
  2.  * 表单提交校验  
  3.  **/  
  4. function onSubmit(){   
  5.     if($('#name').val().length<2){   
  6.         alert("名称请不少于两个汉字");   
  7.         return false;   
  8.     }       
  9.     var flag = true;   
  10.     var t = new Date().getTime();   
  11.     $.ajax({   
  12.         type: "POST",   
  13.         async:false,  // 设置同步方式  
  14.         cache:false,   
  15.         url: "/users/checkrepeat/",   
  16.       data: "name=" + $('#name').val() + "&time=" + t,   
  17.         success:function(res){   
  18.             if(res == 'exists'){   
  19.                 alert("名称已存在,请修改.");   
  20.                 flag = false;   
  21.             }   
  22.         }   
  23.     });   
  24.     if(!flag)   
  25.         return false;   
  26. }   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值