jquery ajax属性async(同步异步)示例


Posted in Javascript onNovember 05, 2013

例1、jquery+ajax/" target="_blank">jquery ajax同步方式

$.ajax({
url : 'test.php',
type : 'post',
async: false,//使用同步的方式,true为异步方式
data : {'act':'addvideo', 'videoname':videoname},//这里使用json对象
success : function(data){
//code here...
},
fail:function(){
//code here...
}
});

例2
//javascript
function test()
{
 var a= 1;
 $.ajax({
  type   : 'GET',
  url    : 'test.php',
  data   : 'page=112',
  success:function(msg)
  {
   alert(msg);
   a= msg;
  }
 })
 alert(a);
}
//test.php
sleef('5'); //休息五分钟
echo 'in';
/*
 这个程序运行情况是  先打印1(a=1) 然后五秒过后 打印 in
 根据这个情况就可以知道 jquery 的ajax的执行流程 
 因为是异步调用
 以前就是这样给一个变量赋值  不管怎么弄都是不对的。最后就发现这个问题
 参数async改为false就为同步调用 当ajax返回结果后程序才继续执行
*/
 

在这里,async默认的设置值为true,这种情况为异步方式,就是说当ajax发送请求后,在等待server端返回的这个过程中,前台会继续 执行ajax块后面的脚本,直到server端返回正确的结果才会去执行success,也就是说这时候执行的是两个线程,ajax块发出请求后一个线程 和ajax块后面的脚本(另一个线程)例:
例3
$.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(),也就是说,在这个时候出现两个线程,我们这里暂且说为function1() 和function2()。
当把asyn设为false时,这时ajax的请求时同步的,也就是说,这个时候ajax块发出请求后,他会等待在function1()这个地方,不会去执行function2(),知道function1()部分执行完毕。
注意
同步的意思是当JS代码加载到当前AJAX的时候会把页面里所有的代码停止加载,页面出去假死状态,当这个AJAX执行完毕后才会继续运行其他代码页面假死状态解除。
而异步则这个AJAX代码运行中的时候其他代码一样可以运行。
jquery的async:false,这个属性
Javascript 相关文章推荐
菜鸟javascript基础资料整理2
Dec 06 Javascript
js内置对象 学习笔记
Aug 01 Javascript
JS获取农历日期具体实例
Nov 14 Javascript
5个数组Array方法: indexOf、filter、forEach、map、reduce使用实例
Jan 29 Javascript
引用jquery框架后出错的解决方法
Aug 09 Javascript
基于Bootstrap的标签页组件及bootstrap-tab使用说明
Jul 25 Javascript
浅析为什么a="abc" 不等于 a=new String("abc")
Oct 25 Javascript
Bootstrap导航菜单点击后无法自动添加active的处理方法
Aug 10 Javascript
vue.js 实现评价五角星组件的实例代码
Aug 13 Javascript
使用vue-cli3新建一个项目并写好基本配置(推荐)
Apr 24 Javascript
基于Fixed定位的框选功能的实现代码
May 13 Javascript
微信小程序 下拉刷新及上拉加载原理解析
Nov 06 Javascript
jQuery Ajax异步处理Json数据详解
Nov 05 #Javascript
Javascript脚本实现静态网页加密实例代码
Nov 05 #Javascript
客户端js性能优化小技巧整理
Nov 05 #Javascript
js倒计时小程序
Nov 05 #Javascript
js实现幻灯片效果(基于jquery插件)
Nov 05 #Javascript
javascript使用location.search的示例
Nov 05 #Javascript
jquery按回车提交数据的代码示例
Nov 05 #Javascript
You might like
一个阿拉伯数字转中文数字的函数
2006/10/09 PHP
destoon安全设置中需要设置可写权限的目录及文件
2014/06/21 PHP
ThinkPHP页面跳转success与error方法概述
2014/06/25 PHP
学习php设计模式 php实现抽象工厂模式
2015/12/07 PHP
PHP缓存工具XCache安装与使用方法详解
2018/04/09 PHP
JS异常处理的一个想法(sofish)
2013/03/14 Javascript
JS 毫秒转时间示例代码
2013/09/22 Javascript
JavaScript instanceof 的使用方法示例介绍
2013/10/23 Javascript
javascript实现文本域写入字符时限定字数
2014/02/12 Javascript
jquery的总体架构分析及实现示例详解
2014/11/08 Javascript
js 将图片连接转换成base64格式的简单实例
2016/08/10 Javascript
AngularJS压缩JS技巧分析
2016/11/08 Javascript
JavaScript动态数量的文件上传控件
2016/11/18 Javascript
javascript实现一个网页加载进度loading
2017/01/04 Javascript
javascript实现页面滚屏效果
2017/01/17 Javascript
JavaScript用200行代码制作打飞机小游戏实例
2017/06/21 Javascript
JS基于for语句编写的九九乘法表示例
2018/01/04 Javascript
解析vue路由异步组件和懒加载案例
2018/06/08 Javascript
详解如何搭建mpvue框架搭配vant组件库的小程序项目
2019/05/16 Javascript
用js实现放大镜效果
2020/10/28 Javascript
python绘制铅球的运行轨迹代码分享
2017/11/14 Python
Numpy截取指定范围内的数据方法
2018/11/14 Python
Linux 修改Python命令的方法示例
2018/12/03 Python
Python tkinter三种布局实例详解
2020/01/06 Python
使用python求解二次规划的问题
2020/02/29 Python
10个顶级Python实用库推荐
2021/03/04 Python
CSS3 transition 实现通知消息轮播条
2020/10/14 HTML / CSS
html5指南-2.如何操作document metadata
2013/01/07 HTML / CSS
Haglöfs瑞典官方网站:haglofs火柴棍,欧洲顶级户外品牌
2018/10/18 全球购物
机械制造专业个人的自我评价
2013/12/28 职场文书
小学教师个人总结
2015/02/05 职场文书
2016年9月份红领巾广播稿
2015/12/21 职场文书
《七律·长征》教学反思
2016/02/16 职场文书
python如何获取网络数据
2021/04/11 Python
Mysql案例刨析事务隔离级别
2021/09/25 MySQL
python中pycryto实现数据加密
2022/04/29 Python