DEV Community

Cover image for What is an API & how to fetch it in React with Hooks? ⚓
Vaibhav Khulbe
Vaibhav Khulbe

Posted on

What is an API & how to fetch it in React with Hooks? ⚓

Whether you are new to APIs or want to use your favourite Hook, this is a tutorial for you. Before going any further into React and stuff, let me introduce you with APIs and how they work so you have a better understanding of what we're about to do.

For this, I assume you already know about React and Hooks. If not the official docs should be enough to get a taste of what they do. Basically, if you want to use React app state without the writing a Class, then Hooks are a great way to jump right in.

The following article might help you in the way:

What's an API and what it does? 🧐

Technically, API stands for Application Programming Interface. But what do those words mean? Okay, here me out...

It's like a shared boundary across which your application and the data from a server (or a database probably) interact and exchange information need to do some action or run the app.

The most common thing you do is make calls (yes, you literally call a method/function of that API) to and from the app. One important thing to note is that an API is not a remote server, rather it's a part of it. The server has the job to receive and send response packets.

There are varied examples on the internet where you interact with APIs and might know at all. We all use Facebook, so whenever you're posting a story, writing comments or reacting to a meme, you're interacting with its server wherein the API works as a middleman between you (client) and the Facebook (server).

Here's a diagram from Perry Eising's article on Medium on how an API comes into the picture:

API diagram

The role of API in an application

You can read the entire article which goes deep into this:

Not all APIs work this way. There are some companies/tools which provide you to access their API calls in order to get that particular data to use it in your projects. These can range from fake user generators like JSONPlaceholder to a SuperHero API. In the end, their main goal is to give you some data to work on.

Get it

Who's ready?

Understanding the API 🔄

In this tutorial though, we will be working with a currency API called Foreign exchange rates API developed by Madis Väin. This is a free service which gets the data from the European Central Bank.

Here's how we use the exchange rates API:

Get the latest currency rates

To get the response, we simply send a GET request:

GET https://api.exchangeratesapi.io/latest HTTP/1.1
Enter fullscreen mode Exit fullscreen mode

But this will give us the rates in Euros (the default base currency).

Get the rates in your own currency

To do this, we simply append ?base parameter. So, if we want to get the value in USD then the above request becomes:

GET https://api.exchangeratesapi.io/latest?base=USD HTTP/1.1
Enter fullscreen mode Exit fullscreen mode

Okay, now we know how it works, let's start a React project!

Using the API in our React app with Hooks 🐱‍💻

Step 1: Empty out the default code and inside App.js add the base URL for the API as a const.

const BASE_URL = 'https://api.exchangeratesapi.io/latest';
Enter fullscreen mode Exit fullscreen mode

Pretty basic step right, well the next one boasts some great stuff. 🔥

Step 2: Fetch the API every time the app is loaded.

We use the useEffect hook to achieve this. As stated this Effect runs after every completed render, hence it's seemingly a good choice here.

1️⃣ Use JavaScript's native fetch to get call the currency rates API, convert the response to JSON and then in the next Promise, we get back the data.

// This will only run the first time our app loads
useEffect(() => {
    fetch(BASE_URL)
      .then((res) => res.json())
      .then((data) => {
        // Code for the next step here
     }
  }, []);
Enter fullscreen mode Exit fullscreen mode

2️⃣ Set application state for our currency options list with the useState Hook. Be default we don't have any initialState therefore we put empty braces in the useState().

const [currencyOptions, setcurrencyOptions] = useState([]);
Enter fullscreen mode Exit fullscreen mode

Next, we write the setcurrencyOptions function inside the .then().

setcurrencyOptions([data.base, ...Object.keys(data.rates)]);
Enter fullscreen mode Exit fullscreen mode

We pass an array. The first value is the data we get back from the API, the second one will be the keys from the JSON Object we get in return. By this, our currency options will be set to this value.

At this step, you can console.log(currencyOptions). What you'll get is the first time it just prints out an empty array but in the second run, it gives all the currency options available from the default EUR to MYR. We now have imported all the base currencies in our app, let's head on to adding some more Hooks.

3️⃣ Next, we want to have a default currency value to show. For this, we again take advantage of the useState() Hook. One will be of the base currency type and the other from which we need to convert to.

const [fromCurrency, setFromCurrency] = useState();
const [toCurrency, setToCurrency] = useState();
...
const firstCurrency = Object.keys(data.rates)[0];
setcurrencyOptions([data.base, ...Object.keys(data.rates)]);
setFromCurrency(data.base);
setToCurrency(firstCurrency);
Enter fullscreen mode Exit fullscreen mode

The setFromCurrency() simply gets that base currency and the setToCurrency() gets the first option of the Object.keys() array. You can go ahead and implement it in your UI code to select/change a particular currency type. Let's now set different amounts.

4️⃣ That same Hook will be responsible to set the amount as:

const [amount, setAmount] = useState(1);
Enter fullscreen mode Exit fullscreen mode

We will let the default value of amount to be 1. We take this a step further by allowing the user to convert both ways simultaneously. So, if they can add the value in the "From" field and get the conversion result in "To" field or vice-versa. The change in one field will directly reflect the other one. For this to work, we need a separate variable to denote this swapping of value fields.

const [exchangeRate, setExchangeRate] = useState();
const [amountInFromCurrency, setAmountInFromCurrency] = useState(true);
...
setExchangeRate(data.rates[firstCurrency]);
Enter fullscreen mode Exit fullscreen mode

We added the boolean true so that it checks if the amount is changed "from" currency or the "to" currency? As for the actual exchange rate value, we have another useState() with no value by default.
Inside the .then(), we set the rate value to the rate we get back from the data object, passing the firstCurrency value. It gives us the actual rate of the currency we select.

5️⃣ At last, we go further in (without any Hooks now 😌), and add a simple logic building to get all the values we need in order to do the conversion.

let toAmount, fromAmount;
  if (amountInFromCurrency) {
    // The 'amount' in state is 'fromAmount'
    fromAmount = amount;
    toAmount = amount * exchangeRate;
  } else {
    // 'amount' is in 'toCurrency'
    toAmount = amount;
    fromAmount = amount / exchangeRate;
  }
Enter fullscreen mode Exit fullscreen mode

So, here it goes. If amountInFromCurrency is true, then it means that the amount value in the state will be in the "from" field. The next link simply multiplies the amount with the exchangeRate value we go from the above step.

If the amount is not in "from", then we do the opposite of multiplication and i.e. (🥁 fake drumroll 🥁) division! Hehe.

Step 3: Update the conversion when we change the currency type.

This bug can simply be removed by using yet another useEffect() Hook:

useEffect(() => {
    if (fromCurrency != null && toCurrency != null) {
      fetch(`${BASE_URL}?base=${fromCurrency}&symbols=${toCurrency}`)
        .then((res) => res.json())
        .then((data) => setExchangeRate(data.rates[toCurrency]));
    }
  }, [fromCurrency, toCurrency]);
Enter fullscreen mode Exit fullscreen mode

We passed both fromCurrency and toCurrency because we need to update whenever any one of those value changes. It's a two-way data binding we're doing!

One new thing you see in the code above is we append &symbols to the BASE_URL. According to the API doc we "Request specific exchange rates by setting the symbols parameter."

GET https://api.exchangeratesapi.io/latest?symbols=USD,GBP HTTP/1.1
Enter fullscreen mode Exit fullscreen mode

Hence we set the base conversion to fromCurrency while symbols takes in all the values we want it to convert. We do this by dynamically setting toCurrency.

If all went well without any crashes or errors, you can simply implement this in your React component code.


Where to next? 🤔

You can move ahead and use APIList.fun to try other APIs, use Hooks and add it to your React projects. Not all APIs are free always, make sure you choose the correct one and according to the project size.


Oh no... Better hit up @docsmsft for help: https://t.co/RKvIJcMltv

Image source: https://t.co/2UdZDZhoLu#DevHumour #Developer #Programming #ICYMI pic.twitter.com/2GpDO8zAmv

— Microsoft Developer UK (@msdevUK) April 25, 2020

📫 Subscribe to my weekly developer newsletter 📫

PS: From this year, I've decided to write here on DEV Community. Previously, I wrote on Medium. If anyone wants to take a look at my articles, here's my Medium profile.

Top comments (0)