I’m trying to fetch data then set that data to a global variable to use throughout my code. So far I am setting the function to a variable called data but this returns extra info i don’t need. is there a way to simply use
data.blahblah
or
data[blahblah]
to access this or do I need to fetch and set the variable itself differently
let dataIndex = "videogames";
title.innerHTML = DATASETS[dataIndex].TITLE;
description.innerHTML = DATASETS[dataIndex].DESCRIPTION;
const getData = (async () => {
let response = await fetch(DATASETS[dataIndex].FILE_PATH);
info = await response.json();
return info;
})().catch((err)=> console.log(err));
const data = getData;
console.log(data)
If I’m understanding you correctly you’re saying write code where i put the comment within the function? I’ve done this on past projects to just get them done so to speak, but it seems weird to me. If I was making something much bigger and complex is this still how it is done or is their alternatives? Sorry for all the questions, I’m just trying to get an idea of what to look for and study for the future. As for this project i’ll probably wrap it in the function and move on with my life lol
No, because JavaScript will continue to process any synchronous code. It does not stop just because some asynchronous code is running (i.e. like fetching some data).
You could just wrap everything in your “main program” in an IIFE and have your data set and other functions like getData outside the IIFE.
const DATASETS = {
videogames: {
TITLE: "Video Game Sales",
DESCRIPTION: "Top 100 Most Sold Video Games Grouped by Platform",
FILE_PATH:
"https://cdn.rawgit.com/freeCodeCamp/testable-projects-fcc/a80ce8f9/src/data/tree_map/video-game-sales-data.json"
}
};
const getData = async (dataIndex) => {
try {
let response = await fetch(DATASETS[dataIndex].FILE_PATH);
info = await response.json();
return info;
} catch (err) {
console.log(err);
}
};
const getTopSellingConsoleGame = (data, whichConsole) => {
const consoleSales = data.children.filter(({ name }) => name === whichConsole);
return consoleSales[0].children[0].name;
};
// main program
(async () => {
let dataIndex = "videogames";
const data = await getData(dataIndex);
// do more stuff with data here
const topSellingPS4Game = getTopSellingConsoleGame(data, 'PS4');
console.log(topSellingPS4Game) // Call of Duty: Black Ops 3
})();