在这里,我试图围绕promise承担我的头。在第一次请求时,我获取一组links.and下一个请求我获取第一个链接的内容。但是我想在返回下一个承诺object.So我上它。但是它给了我下面的JSON错误(without setTimeout() it works just fine
)在承诺链上使用setTimeout
SyntaxError: JSON.parse: unexpected character at line 1 column 1 of the JSON data
我想知道为什么它没有使用的setTimeout?
let globalObj={};
function getLinks(url){
return new Promise(function(resolve,reject){
let http = new XMLHttpRequest();
http.onreadystatechange = function(){
if(http.readyState == 4){
if(http.status == 200){
resolve(http.response);
}else{
reject(new Error());
}
}
}
http.open("GET",url,true);
http.send();
});
}
getLinks('links.txt').then(function(links){
let all_links = (JSON.parse(links));
globalObj=all_links;
return getLinks(globalObj["one"]+".txt");
}).then(function(topic){
writeToBody(topic);
setTimeout(function(){
return getLinks(globalObj["two"]+".txt"); // without setTimeout it works fine
},1000);
});
请注意,'return'是函数特有的,只返回父函数,并且不能从异步方法返回。 – adeneo
注意有很多[更好的方法](http://stackoverflow.com/q/28250680/1048572)来构造这个代码,而不是使用'globalObj'。 – Bergi
'JSON.parse'扔在哪里?我很难相信在一个“then”回调中是否存在'setTimeout'会影响前一个'then'回调中的调用。 – Bergi