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


Posted in Javascript onJuly 10, 2013
/**
 * 表单提交校验
 **/
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;
            }
        }
    });
}

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

修改后的代码:

/**
 * 表单提交校验
 **/
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;
Javascript 相关文章推荐
json简单介绍
Jun 10 Javascript
jquery的extend和fn.extend的使用说明
Jan 09 Javascript
编写自己的jQuery插件简单实现代码
Apr 19 Javascript
jQuery 翻牌或百叶窗效果(内容三秒自动切换)
Jun 14 Javascript
zTree插件下拉树使用入门教程
Apr 11 Javascript
jQuery+Ajax实现限制查询间隔的方法
Jun 07 Javascript
Javascript字符串常用方法详解
Jul 21 Javascript
jquery实现点击页面回到顶部
Nov 23 Javascript
canvas 画布在主流浏览器中的尺寸限制详细介绍
Dec 15 Javascript
Bootstrap笔记之缩略图、警告框实例详解
Mar 09 Javascript
Vue中v-for的数据分组实例
Mar 07 Javascript
React Native基础入门之初步使用Flexbox布局
Jul 02 Javascript
JavaScript 模拟类机制及私有变量的方法及思路
Jul 10 #Javascript
js固定DIV高度,超出部分自动添加滚动条的简单方法
Jul 10 #Javascript
javascript 手动给表增加数据的小例子
Jul 10 #Javascript
基于javascript 闭包基础分享
Jul 10 #Javascript
关于include标签导致js路径找不到的问题分析及解决
Jul 09 #Javascript
等待指定时间后自动跳转或关闭当前页面的js代码
Jul 09 #Javascript
浅析js封装和作用域
Jul 09 #Javascript
You might like
什么情况下可以不写PHP的闭合标签“?&gt;”
2014/08/28 PHP
实例讲解如何在PHP的Yii框架中进行错误和异常处理
2016/03/17 PHP
php面向对象编程self和static的区别
2016/05/08 PHP
php基于 swoole 实现的异步处理任务功能示例
2019/08/13 PHP
Laravel5.1框架路由分组用法实例分析
2020/01/04 PHP
JavaScript 不只是脚本
2007/05/30 Javascript
基于JQuery的Pager分页器实现代码
2010/07/17 Javascript
js实现addClass,removeClass,hasClass的函数代码
2011/07/13 Javascript
JS跨域总结
2012/08/30 Javascript
JavaScript利用正则表达式去除日期中的“-”
2014/07/01 Javascript
jquery实现具有嵌套功能的选项卡
2016/02/12 Javascript
微信js-sdk界面操作接口用法示例
2016/10/12 Javascript
Node.js中如何合并两个复杂对象详解
2016/12/31 Javascript
vue实现文章内容过长点击阅读全文功能的实例
2017/12/28 Javascript
JS简单实现查看文档创建日期、修改日期和文档大小的方法示例
2018/04/08 Javascript
微信小程序合法域名配置方法
2019/05/06 Javascript
jquery多级树形下拉菜单的实例代码
2019/07/09 jQuery
你可能从未使用过的11+个JavaScript特性(小结)
2020/01/08 Javascript
微信小程序点击item使之滚动到屏幕中间位置
2020/03/25 Javascript
js实现特别简单的钟表效果
2020/09/14 Javascript
JavaScript中的Proxy对象
2020/11/27 Javascript
python脚本实现分析dns日志并对受访域名排行
2014/09/18 Python
Python多线程编程(六):可重入锁RLock
2015/04/05 Python
Python同时向控制台和文件输出日志logging的方法
2015/05/26 Python
numpy判断数值类型、过滤出数值型数据的方法
2018/06/09 Python
对django中render()与render_to_response()的区别详解
2018/10/16 Python
详解Python可视化神器Yellowbrick使用
2019/11/11 Python
python定义类self用法实例解析
2020/01/22 Python
Python如何实现线程间通信
2020/07/30 Python
Herschel Supply Co.美国:背包、手提袋及配件
2020/11/24 全球购物
医大实习自我鉴定
2013/12/07 职场文书
前处理班长职位说明书
2014/03/01 职场文书
对外汉语专业大学生职业生涯规划书
2014/10/11 职场文书
个人总结与自我评价
2015/02/14 职场文书
施工安全保证书
2015/05/09 职场文书
Mysql多层子查询示例代码(收藏夹案例)
2022/03/31 MySQL