10 Aug 2021 7 min read
Photo by Mia Anderson on Unsplash
I think this is the most important topic in JS or you can say in Web development. Being a developer it's part of our job to work with backend and fetching information from the databases or from the internet. So knowing fetch is very essential for every web developer. I made this tutorial for simply get you started with fetch API and little bit of async/await so you can use it in the further projects.
Fetch API is one of the simplest way to make asynchronous HTTP request in the web browser. It uses JS Promises to deliver more flexible features for making requests on the browser. Fetch method returns a Promise so we can make use of .then() and .catch() methods to handle the response.
This is example of fetch request in node.js. You apply the same this tutorial with from part 2 for vanilla JS, fetch is available in vanilla JS out of the box so you don't have to go through the npm package installation.
We first need to create a directory with and start the npm project in the same directory then create a javascript file.
mkdir weather-app
npm init -y
touch app.js
Installing "node-fetch" npm package.
npm i node-fetch --save
In the app.js file we have to import the package, for importing the package we have to use require statement as follows:
const fetch = require("node-fetch")
Now we can use the fetch module.
For demonstration I will be using openweathermap API . Its free to use you can sign up for it here and go to account page and get you API_KEY.
Now we can make a http request by passing the url in fetch method. First we will make a simple fetch request for checking if our API call works and then logging the data to the console.
But first lets check out the code how its actually working?. We are passing the URL in fetch so, it will return a response object which has all the information we need, provided our URL and API is correct. If we pass wrong url or API key we will get an error object.
This function will return a Promise in order to handle the promise we will use .then() is a method callback which is available after a promise is resolved. Promise is resolved means the request was successful and there is no error. The .catch() method deals with rejected cases only when the request is not resolved it will return the block of code in the .catch() method. And I'm using arrow function as callback functions inside .then and ,catch.
fetch(
"https://api.openweathermap.org/data/2.5/weather?q=mumbai&units=metric&APPID=YOUR_KEY"
)
.then(response => response.json())
.then(data => console.log(data))
.catch(err => console.log(err))
We can just run following :
node app.js
If everything works out, you will get this response in your console, this is JS Object so we can pull out the information as we need and render it on the front end.
Successful response:
{
coord: { lon: 72.85, lat: 19.01 },
weather: [ { id: 721, main: 'Haze', description: 'haze', icon: '50d' } ],
base: 'stations',
main: {
temp: 31.49,
feels_like: 34.13,
temp_min: 31,
temp_max: 32,
pressure: 1006,
humidity: 70
},
visibility: 5000,
wind: { speed: 5.7, deg: 300 },
clouds: { all: 40 },
dt: 1599127310,
sys: {
type: 1,
id: 9052,
country: 'IN',
sunrise: 1599094455,
sunset: 1599139321
},
timezone: 19800,
id: 1275339,
name: 'Mumbai',
cod: 200
}
If the key is wrong will look error will look something like this:
{
cod: 401,
message: 'Invalid API key. Please see http://openweathermap.org/faq#error401 for more info.'
}
We will further see how to catch the error and return a meaning full response in the dev console using try catch block.
In javascript there is a special syntax to work with promises i.e async/await
Now coming back to our example here we are creating a new function which returns the response from the fetch call i.e either a resolved promise(object with valid weather info) or rejected promise(error object). In the method first we are using await to wait till the fetch is response is settled.
The function execution will pauses on the line where await is called and resumes when the promise is settled. It doesn’t cost any CPU resources, because the JavaScript engine can do other jobs in the meantime: execute other scripts, handle events, etc.
And in the end we are just calling the getWeather method.
async function getWeather() {
const weather = await fetch(
"https://api.openweathermap.org/data/2.5/weather?q=mumbai&units=metric&APPID=YOUR_KEY"
)
let response = await weather.json()
console.log(response)
}
getWeather()
this function will be immediately invoked as the name suggests. And I have used try and catch block for handling exceptions. This instead of storing the weather info in a variable we can directly use use url with fetch. Instead of just logging the data we can use specific info on the response object and store it in a variable. and then use it front end for showing weather information.
;(async () => {
await fetch(
"https://api.openweathermap.org/data/2.5/weather?q=mumbai&units=metric&APPID=YOUR_KEY"
)
.then(response => response.json())
.then(data => {
const forecast = data.weather[0].description
const temperature = data.main.temp
const name = data.name
console.log(`Today's forecast for ${name}: ${forecast}`)
console.log(`It's currently ${temperature}°C `)
})
.catch(console.log(`Error: ${err}`))
})()
Today's forecast for Mumbai: haze
It's currently 30°C