码迷,mamicode.com
首页 > Web开发 > 详细

ajax中同步和异步

时间:2015-10-15 19:02:28      阅读:173      评论:0      收藏:0      [点我收藏+]

标签:

一、async值为true (异步

当ajax发送请求后,在等待server端返回的这个过程中,前台会继续 执行ajax块后面的脚本,直到server端返回正确的结果才会去执行success,也就是说这时候执行的是两个线程,ajax块发出请求后一个线程 和ajax块后面的脚本(另一个线程)

 

例如

 

$.ajax({   

         type:"POST",  

         url:"Venue.aspx?act=init",  

         dataType:"html",  

         success:function(result){   //function1()

             f1();  

             f2();  

         }  

         failure:function (result) {   

            alert(‘Failed‘);   

         },  

  }  

  function2();

 

在上例中,当ajax块发出请求后,他将停留function1(),等待server端的返回,但同时(在这个等待过程中),前台会去执行function2()。

 


二、async值为false (同步

当执行当前AJAX的时候会停止执行后面的JS代码,直到AJAX执行完毕后时,才能继续执行后面的JS代码。

 

例如

 

$.ajax({   

        type:"POST",  

        url:"Venue.aspx?act=init",  

        dataType:"html",  

        async: false,

        success:function(result){   //function1()
 
             f1();  

             f2();  

         }  

        failure:function (result){   

            alert(‘Failed‘);   

         },  

  }  

  function2();

这个时候ajax块发出请求后,他会等待在function1()这个地方,不会去执行function2(),直到function1()部分执行完毕。



参考资料: ajax同步和异步的区别  http://www.studyofnet.com/news/1025.html


ajax中同步和异步

标签:

原文地址:http://my.oschina.net/u/2428791/blog/517660

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!