关于jquery的ajax队列的一些问题

今天开发的时候遇到一个需求是要做一个更新的进度条。


呃。。。


看了鸟哥的blog,php5.4里面超级session里面可以打印出某个文件的上传进度。。

鸟哥原话:

在PHP5.4以前, 我们可以通过APC提供的功能来实现. 或者使用PECL扩展uploadprogress来实现.

这个新特性, 提供了一些新的INI配置, 他们和APC的相关配置很类似:

  • session.upload_progress.enabled[=1] : 是否启用上传进度报告(默认开启)
  • session.upload_progress.cleanup[=1] : 是否在上传完成后及时删除进度数据(默认开启, 推荐开启).
  • session.upload_progress.prefix[=upload_progress_] : 进度数据将存储在_SESSION[session.upload_progress.prefix . _POST[session.upload_progress.name]]
  • session.upload_progress.name[=PHP_SESSION_UPLOAD_PROGRESS] : 如果_POST[session.upload_progress.name]没有被设置, 则不会报告进度.
  • session.upload_progress.freq[=1%] : 更新进度的频率(已经处理的字节数), 也支持百分比表示’%’.
  • session.upload_progress.min_freq[=1.0] : 更新进度的时间间隔(秒级)
经过一轮轮尝试之后觉得这个东西倒不如ajax的方式来的实在。


但后面的问题又出来了,ajax是异步的,他不能保证按照顺序来,我写一个for循环,可能for循环过了后台那边还没有响应。


所以必须要做一个类似于队列的东西来解决这个东西。


于是想到了jQuery.quene();

啪啪啪代码出来了


// 第一个ajax请求
$(document).queue("ajaxRequests", function(){
    //全局变量,储存第一个ajax请求数据
    var a_data;
    $.ajax({
        success: function(data){
            a_data = data;
            $(document).dequeue("myName");
        }
    });
});
// 第二个ajax请求
$(document).queue("ajaxRequests", function() {
  $.ajax({
    success: function(data) {
      alert(a_data);
      $(document).dequeue("myName");
    }
  });
});
// 触发queue往下执行
$(document).dequeue("ajaxRequests");

但是为何不用递归呢????

后面还是想着用递归比较直白:
 
 //初始化identity为0
	 function getajax(identity,num){
		$.post("./index.php?g=System&m=Update&a=ajaxdownload",{},function(msg){
					if(identity<num){
						updateProgress("更新"+msg+"版本号",400/num+identity*400/num);
						getajax(identity+1,num);
					}else{
					updateProgress("更新完毕!",400);
					}		
			  },'json')
	 }


你可能感兴趣的:(关于jquery的ajax队列的一些问题)