在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
提交
取消