27.3. Exercises¶
27.3.1. Fetch¶
To practice fetching data, create a file called fetch_planets.html
using touch
in your terminal.
Add this preliminary HTML to your fetch_planets
document:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | <!DOCTYPE html>
<html>
<head>
<title>Fetch Planets</title>
<script>
window.addEventListener("load", function(){
// TODO: fetch planets JSON
});
</script>
</head>
<body>
<h1>Destination</h1>
<div id="destination">
<h3>Planet</h3>
</div>
</body>
</html>
|
The URL where our planet data is located is:
"https://handlers.education.launchcode.org/static/planets.json"
. Add the code to fetch this URL inside the load event listener.Peek at the
response
returned in the request by adding a print statement inside of the function.Copy the file path of your HTML file and paste it as the URL in your browser. You won't see much on the page yet. Open your developer tools and examine both the Console tab for the response value, as well as the Network tab for the request status.
Use the
.json()
method on your response now to see more of the data in the console: What data type do you see printed?Replace your
console.log(json)
with the following to view a portion of the JSON into the app.1 2
const destination = document.getElementById("destination"); destination.innerHTML = `<h3>Planet ${json[0].name}</h3>`;
Refresh the page to see some new data in your HTML. Play around by changing the index number. Does the planet name change? Can you change the planet's property being printed?
Now, what happens if we move those last lines we added to outside and after the fetch request?
Since
json
hasn't been defined outside of theresponse.json()
method yet, in order to move the template literal that uses thatjson
variable, we'll need to initiate it outside of the function call. Let's also put our print statement back so we can verify that our fetch works.Refresh the page and try this. See any data? See anything of note in the console?
Our last task left us with some knowledge about where and how we can use the fetched data, but we don't really want to keep those changes. Instead, how about we use an event to change the planet information we see? Let's move the DOM manipulation to inside a click handler.
1 2 3 4 5 6 7 8 9 10 11 12 13
fetch("https://handlers.education.launchcode.org/static/planets.json").then(function(response){ response.json().then(function(json) { const destination = document.getElementById("destination"); destination.addEventListener("click", function(){ destination.innerHTML = ` <div> <h3>Planet ${json[0].name}</h3> <img src=${json[0].image} height=250></img> </div> `; }); }); });
Now, after refreshing the page, you can click on the
Planet
header to make the name and image appear. Take note, we're still fetching on load, just not displaying the data until the the header is clicked.For fun and good measure, let's dynamically change which planet's info we're displaying each time the header is clicked. To do this,
Declare a counter variable,
index
that changes each time aclick
event takes place.Use the value of
index
as the position in the planets array to use in the template literal.Finally, since we want to cap the value of
index
so that it does not exceed the length of the planets array, use a modulo to control how largeindex
can get.
Et voila! Our destination changes on each click!
Put on your planetary shoes. We are moving through planets!