源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2020-01-21 19:47 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:浅析onsubmit校验表单时利用ajax的return false无效问题
[u]复制代码[/u] 代码如下:
/**  * 表单提交校验  **/ function onSubmit(){     if($('#name').val().length<2){         alert("名称请不少于两个汉字");         return false;     }     var t = new Date().getTime();     $.ajax({         type: "POST",         url: "/users/checkrepeat/",    data: "name=" + $('#name').val() + "&time=" + t,         success:function(res){             if(res == 'exists'){                 alert("名称已存在,请修改.");                 return false;             }         }     }); }
[b]问题原因: [/b]1. ajax时return false 的function与onsubmit()不是同一个函数; 2. 在ajax执行时,async默认的设置值为true,这种情况为异步方式,就是说当ajax发送请求后,在等待server端返回的这个过程中,前台会继续 执行ajax块后面的脚本,直到server端返回正确的结果才会去执行success,也就是说这时候执行的是两个线程,ajax块发出请求后一个线程 和ajax块后面的脚本(另一个线程)。 [b]修改后的代码: [/b]
[u]复制代码[/u] 代码如下:
/**  * 表单提交校验  **/ function onSubmit(){     if($('#name').val().length<2){         alert("名称请不少于两个汉字");         return false;     }        var flag = true;     var t = new Date().getTime();     $.ajax({         type: "POST",         async:false,  // 设置同步方式         cache:false,         url: "/users/checkrepeat/",    data: "name=" + $('#name').val() + "&time=" + t,         success:function(res){             if(res == 'exists'){                 alert("名称已存在,请修改.");                 flag = false;             }         }     });     if(!flag)         return false;
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部