在effective javascript看到这么个观点:绝对不能对异步回调函数(即使在数据已经就绪)进行同步调用。如果对异步回调函数进行同步调用的话,处理顺序可能会与预期不符,可能带来意料之外的后果。这样说的原因是不是因为对于异步的回调函数,如果同步执行这个回调函数的话,可能javascript的消息队列中还存在没有执行完的任务,如果同步执行这个回调函数的话可能打破正常的一个执行流程。所以对于异步的回调函数推荐使用异步调用,这样会等到消息队列中任务清空之后再执行这个回调?不知道我这样理解是否正确,请各位点评一下。
                    
                    
                1 回答
                            守候你守候我
                            
                                
                            
                        
                        
                                                
                    TA贡献1802条经验 获得超10个赞
举个栗子:
var a = 0;function task(callback) {
  setTimeout(function () {
    a = 1;    typeof callback === 'function' && callback(); 
  }, 1000);
}function taskCb() {  console.log(a);
}
task();
taskCb(); // a = 0;如果同步执行taskCb,结果是 a = 0,而不是想要的a = 1,因为执行时 任务task并未完成,并未返回结果。
应该酱紫:
task(taskCb);
或者说是酱紫(同一个意思):
task(function () {
  taskCb();
});实际使用中的异步任务可能是ajax请求,文件操作等,这里用setTimeout举例啦
添加回答
举报
0/150
	提交
		取消
	