Ось я намагаюся обернути голову навколо обіцянок. Ось за першим запитом я отримую набір посилань. І на наступний запит я вибираю вміст першої посилання. Але я хочу зробити затримку перед поверненням наступного об'єкта обіцянки. Тому я використовую setTimeout на ньому. Але це дає мені таку помилку JSON ( without setTimeout() it works just fine
)
SyntaxError: JSON.parse: несподіваний символ у колонці 1 рядка 1 даних JSON
я хотів би знати, чому це не вдається?
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);
});
globalObj
.
JSON.parse
кидає? Мені важко повірити, що наявність зворотного дзвінка setTimeout
в одному then
впливає на виклик у попередньому then
зворотному дзвінку .
return
це функція, яка повертається лише до батьківської функції, і що ви не можете повернутися з методу асинхронізації.