I am attempting to read the product page of a certain website, however I get an error on line 27, stating that goXML does not have a function named listChildren, along with all other p5 .xml functions. However, xml, a variable defined earlier in the code, works just fine. Is there something I’m missing here, because to me I should be able to access those functions.
Thanks.
var xml;
var json;
function preload() {
xml = loadXML('https://undefeated.com/collections/new.atom');
json = loadJSON('https://undefeated.com/collections/new.json');
}
function setup() {
// put setup code here
var allChildren = xml.listChildren();
var products_raw = xml.getChildren('entry');
var products = [];
for (var i = 0; i < products_raw.length; i++) {
var title = products_raw[i].getChild('title');
var link = products_raw[i].getChild('link').attributes.href + '.xml';
var tags = products_raw[i].getChildren('s:tag');
console.log(link.type);
products.push(new Product(title, link, tags));
}
var goXML = loadXML(products[0].link);
console.log(goXML);
console.log(goXML.type);
var variants = goXML.listChildren();
}
function draw() {
// put drawing code here
}
function Product(title, link, tags) {
this.title = title;
this.link = link;
this.tags = tags;
}```
Of course it works! B/c it’s in the right place, inside preload(), which fully loads assets before setup() starts: data:image/s3,"s3://crabby-images/8a408/8a408f7b825001a7f1f7b3ac25fbd3a9057c4717" alt=":star_struck: :star_struck:"
Well, the statement var goXML = loadXML(products[0].link);
happens after preload() is long over. data:image/s3,"s3://crabby-images/75d2b/75d2ba76cddf343d284ef69a498cffa6938b8ef9" alt=":slightly_frowning_face: :slightly_frowning_face:"
Easiest fix is simply moving it to preload() like the 1s already there. data:image/s3,"s3://crabby-images/0aa4a/0aa4a0bc7d1dad18f472995186a10c81032ccc9d" alt=":bulb: :bulb:"
However, this particular asset loading depends on xml to be already 100% loaded! data:image/s3,"s3://crabby-images/c0de4/c0de4e444af2d41696c42095d62969a44bffab28" alt=":sweat: :sweat:"
In such case, you may try to chain-load it right after xml is done. data:image/s3,"s3://crabby-images/723d8/723d820d27f53933b9518bd693cb95a439741115" alt=":chains: :chains:"
In order to pull that out, pass a success callback as its 2nd parameter: data:image/s3,"s3://crabby-images/bfe58/bfe58601c671e936875ce743b7d8441ae017011c" alt=":calling: :calling:"
xml = loadXML('https://undefeated.com/collections/new.atom', loadProducts);
Notice the variable loadProducts as the 2nd argument of loadXML() there. data:image/s3,"s3://crabby-images/4f6b6/4f6b6b50fb71022076b8e622faa0a765af3e23f8" alt=":warning: :warning:"
It’s supposed to be the function loadXML() calls back when the loading is 100% fully done. data:image/s3,"s3://crabby-images/77c56/77c56d64ef7347eb7de09df15e5c5bf8086fdec1" alt=":100: :100:"
Now, move your whole products code inside that loadProducts() callback function, including both the loop and the 2nd loadXML(). data:image/s3,"s3://crabby-images/8a2c8/8a2c85ab0d7477414d6351bfdd737a84ea6a52ec" alt=":innocent: :innocent:"
All of that is gonna happen before setup() even starts! data:image/s3,"s3://crabby-images/b459d/b459d23377e8d58893bc032c787a1db20b68cc34" alt=":smile_cat: :smile_cat:"
Here’s a sketch which does something very similar:
- Online sketch: ThimbleProjects.org/gotoloop/96556/
- Source code: ThimbleProjects.org/gotoloop/96556/sketch.js
That sketch needs to load images whose links are inside a “.csv” file:
ThimbleProjects.org/gotoloop/96556/players.csv
So it 1st loads it within preload():
function preload() {
loadTable(FILENAME, createPlayers);
}
Once the “.csv” file asset is complete, it calls back createPlayers():
function createPlayers(table) {
players.length = 0, entries = table.getRowCount();
for (const r of table.getRows()) players.push(
new Player(loadImage(r.getString(0)), r.getString(1), r.getNum(2))
);
}
Which in turn invokes loadImage() inside its loop. data:image/s3,"s3://crabby-images/a2c6b/a2c6bad352a9eb3b490a14ae12e43c770692da99" alt=":cowboy_hat_face: :cowboy_hat_face:"
And when setup() finally starts, all resources are 100% ready to be used for the rest of the sketch! data:image/s3,"s3://crabby-images/3f522/3f5223df0c680ae2f3cdf638ba126b07c7cf8fc3" alt=":partying_face: :partying_face:"
Wow thank you man, you have been really helpful!