看了半天终于看懂楼主的问题。
楼主需要先理解一下javascript执行代码的循环机制
假设有一个异步方法
async(url,err,cb)
//[数字]表示执行的顺序
var myData; //[1]
async("someurl"
,err=>{
myData = err;
}
,data=>{ //[2]
myData = data //[5]只要这是一个异步方法的回调,他就会在外部所有代码执行完之后才会执行
})
console.log(myData)//[3] 结果是undefined,因为此时myData是还没被定义的。
for(var i=0;i<3;i++){//[4]
}
同理楼主是不可能在此后的代码中获得data的,因为异步方法总会(至少会)在所有"外部"代码执行完之后才会执行,即便setTimeOut(cb,0)也是
但这样的结构不利于体现程序的执行流程。
于是出现了很多异步流程的控制方法或者思想(例如async和Promise等等)
例如我们把async封装一下
function asyncBird(url){
var _cbErr = ()=>{}
var _cb = ()=>{}
var result = {
err:function(cbErr){
_cbErr = cbErr;
return result;
}
,success:function(cb){
_cb = cb;
return result;
}
}
async(url,_cbErr,_cb);
return result;
}
asyncBird("someurl")
.successs(data=>{
})
.err(err=>{
console.log(err);
for(var i=0;i<3;i++){
}
})
和Promise是类似,这样子流程就会清晰很多,或许这是楼主要的效果。