var log = function(value){
var logdiv = document.getElementById("logdiv");
logdiv.innerHTML=logdiv.innerHTML+value+"<br/>";
}
var value;
var A = function (callback){
setTimeout(function(){
if (value > 0){
value = value + 20;
}else{
value = 20;
}
callback();
},100);
}
var B = function(callback){
log(value);
callback();
}
//保证 A();B(); 调用后value有值
var queue = function(funcs,scope){
(function next(){
if(funcs.length > 0){
//shift 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。
//apply 应用某一对象的一个方法,用另一个对象替换当前对象。
funcs.shift().apply(scope || {}, [next].concat(Array.prototype.slice.call(arguments, 0)));
}
})();
}
queue([A,A,A,A,A,B,A,B]);
学习blog
http://blog.youkuaiyun.com/renfufei/article/details/19428719
本文通过一个JavaScript函数队列的实现案例,展示了如何使用setTimeout和回调函数来管理异步任务。此示例有助于理解JavaScript的异步执行机制及事件循环。
2810

被折叠的 条评论
为什么被折叠?



