runliuv

runliuv@cnblogs

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
var flat=false;             return flat;      async:false,        是重点。
 

执行ajax时return false的function 与onsubmit()不是同一个函数,所以无论return 什么都会直接执行submit()提交表单

 

在执行ajax时,async默认的默认值为true,这种情况为异步方式,就是说ajax发送请求后,在等待服务端返回的这个过程中,前台会继续执行ajax块后面的脚本,直到服务端返回正确的结果才会执行success,也就是说这时执行的是两个线程,一个线程在执行ajax时另一个进程已经执行return flat了。所以一直返回false.把async改为false,这时才是同步方式,只有一个线程。

 

function checksubmit(){
             var flat=false;
             var re_email=new RegExp("\\w+@\\w+\\.\\w+\\.?\\w*");
             var newEmail=$("#email_new").val();
             if(re_email.test(newEmail)){
                 $.ajax({
                     type:"post",
                     dataType:"json",
                     async:false,//同步方式
                     url:"existEmail?email="+newEmail,
                     success:function(dataResult){
                         if(dataResult=="true"){
                             $("#emial-error").text("邮箱已注册。");
                             flat=false;
                         }else{
                             flat=true;
                         }
                     }
                 });
             }else{
                 $("#emial-error").text("邮箱格式不正确。");
                 return false;
             }
             return flat;
         }
 

 

checksubmit() 在MVC 中的位置 。

@using (Html.BeginForm("Create", "payMerchant", new { area = "Pay" }, FormMethod.Post, new { id = "payMerchant_cr", @class = "am-form am-form-horizontal", enctype = "multipart/form-data", onsubmit = "return checksubmit()" }))

 


---------------------
作者:Boh_
来源:CSDN
原文:https://blog.csdn.net/u010079945/article/details/38680769
版权声明:本文为博主原创文章,转载请附上博文链接!

 

posted on 2019-01-30 15:56  runliuv  阅读(204)  评论(0编辑  收藏  举报