In order to fully explain how the fetch
function works, we need to define
and talk about the terms asynchronous and synchronous.
Asynchronous: Not simultaneous or concurrent in time.
Synchronous: Simultaneous or concurrent in time.
When fetching data in JavaScript, the HTTP requests are asynchronous. In brief, that means when an HTTP request is sent, we don't know exactly when a response will be received by the browser. Remember that HTTP requests are sent to an address, then a response is sent. That process takes a variable amount of time depending on network speed, the address location, and response size.
Note
These requests are also called AJAX requests (Asynchronous JavaScript and XML). The XML part of AJAX refers to a data format that was popular before JSON.
Browsers can't stop everything and wait for a response to an HTTP request. Browsers have to render HTML, interact with the user, and run JavaScript. To keep these processes running seamlessly, without any noticeable pauses, the browser relies on events.
This is where .then()
and the response handler function come in. The browser
provides us with a way to handle the response whenever it is received.
then
Function¶Let's look again at a simple fetch
example. Notice on line 1 that then
is
called on the value returned from fetch
.
1fetch("https://handlers.education.launchcode.org/static/weather.json").then( function(response) {
2 console.log(response);
3} );
To make it clearer, let's capture the value returned by fetch
in a variable
named fetchPromise
.
1const fetchPromise = fetch("https://handlers.education.launchcode.org/static/weather.json");
2fetchPromise.then( function(response) {
3 console.log(response);
4} );
fetch
returns an instance of the Promise
class. The Promise
class
represents a promise. A promise is the eventual outcome of an asynchronous event.
In the above example, fetchPromise
represents the eventual response from the HTTP request to
https://handlers.education.launchcode.org/static/weather.json
.
A promise can be fulfilled or rejected. When a promise is fulfilled, data is passed
to the response handler function. The then
method of Promise
defines what will
happen when the promise is fulfilled. When a promise is rejected, the error reason is
returned.
The above example can be translated to these steps
https://handlers.education.launchcode.org/static/weather.json
response
objectAbove, we showed a promise representing the outcome of an HTTP request, however, promises can represent the outcome of any asynchronous event.
For example, the response
object has a json()
function that will return the JSON data in the
response. The json()
function returns a promise that represents the future result
of turning the response data into JSON.
The example below shows how promises are used to represent two different types of asynchronous events and the outcomes.
Example
1const fetchPromise = fetch("https://handlers.education.launchcode.org/static/weather.json");
2fetchPromise.then( function(response) {
3 const jsonPromise = response.json();
4 jsonPromise.then( function(json) {
5 console.log("temp", json.temp);
6 });
7} );
This example involves two promises. On line 1, fetchPromise
is a promise that represents the
fetch request. On line 3, jsonPromise
is a promise that represents the response data being turned
into JSON.
Finally on line 5, the JSON data can be logged.
Tip
Promises can be a hard concept to understand. Focus on the examples and the theory will make sense in time.
Question
We know exactly when an asynchronous request will return.
Question
A promise can represent the outcome of any future event.
Question
then
is a method of the Promise
class that allows us to run code
after an event is completed.