我正在学习javascript和json,但我遇到了一些问题:我有一个脚本可以与json一起使用,但是我写的内容的表现并不好。该代码仅在我使用萤火虫或其他工具一步一步地进行调试时才起作用,并且这使我认为代码的执行(或其中的一部分......创建表的那一部分,如您所见)需要浏览器停止了太多时间。JavaScript代码的异步执行
的代码是:
var arrayCarte = [];
var arrayEntita = [];
var arraycardbyuser = [];
function displayArrayCards() {
var richiestaEntity = new XMLHttpRequest();
richiestaEntity.onreadystatechange = function() {
if(richiestaEntity.readyState == 4) {
var objectentityjson = {};
objectentityjson = JSON.parse(richiestaEntity.responseText);
arrayEntita = objectentityjson.cards;
}
}
richiestaEntity.open("GET", "danielericerca.json", true);
richiestaEntity.send(null);
for(i = 0; i < arrayEntita.length; i++) {
var vanityurla = arrayEntita[i].vanity_urls[0] + ".json";
var urlrichiesta = "http://m.airpim.com/public/vurl/";
var richiestaCards = new XMLHttpRequest();
richiestaCards.onreadystatechange = function() {
if(richiestaCards.readyState == 4) {
var objectcardjson = {};
objectcardjson = JSON.parse(richiestaCards.responseText);
for(j = 0; j < objectcardjson.cards.length; j++)
arrayCarte[j] = objectcardjson.cards[j].__guid__; //vettore che contiene i guid delle card
arraycardbyuser[i] = arrayCarte;
arrayCarte = [];
}
}
richiestaCards.open("GET", vanityurla, true);
richiestaCards.send(null);
}
var wrapper = document.getElementById('contenitoro');
wrapper.innerHTML = "";
var userTable = document.createElement('table');
for(u = 0; u < arrayEntita.length; u++) {
var userTr = document.createElement('tr');
var userTdcard = document.createElement('td');
var userTdinfo = document.createElement('td');
var br = document.createElement('br');
for(c = 0; c < arraycardbyuser[u].length; c++) {
var cardImg = document.createElement('img');
cardImg.src = "http://www.airpim.com/png/public/card/" + arraycardbyuser[u][c] + "?width=292";
cardImg.id = "immaginecard";
userTdcard.appendChild(br);
userTdcard.appendChild(cardImg);
}
var userdivNome = document.createElement('div');
userdivNome.id = "diverso";
userTdinfo.appendChild(userdivNome);
var userdivVanity = document.createElement('div');
userdivVanity.id = "diverso";
userTdinfo.appendChild(userdivVanity);
var nome = "Nome: ";
var vanityurl = "Vanity Url: ";
userdivNome.innerHTML = nome + arrayEntita[u].__title__;
userdivVanity.innerHTML = vanityurl + arrayEntita[u].vanity_urls[0];
userTr.appendChild(userTdcard);
userTr.appendChild(userTdinfo);
userTable.appendChild(userTr);
}
wrapper.appendChild(userTable);
}
的问题是,应该让表中的代码不等待与JSON文件的工作代码的完整执行。我该如何解决它?如果可能的话,我宁愿用简单的东西来解决这个问题,而不用jQuery和回调(我是一个初学者)。
我在尝试,但如果我从displayArrayCards中调用BuildArrayEntita(就像你做的那样)它不起作用(这就是为什么我没有使用不同的函数,而我把所有的代码放在一个方法中)。 – user1453638
什么不工作?你是否试图检查你的objectivityjson.cards以确保它包含你期望它包含的内容。尝试放入console.log(“ - unique text--”);在每个方法的开始(以及onreadystatechange函数中)。然后你可以看到执行的顺序。 – Dappergoat
我在这里和那里有一些提醒,以了解发生了什么,但我看不到其中之一。 – user1453638