Top 10 Essential Features of Poke API — Ultimate Guide

Jennie Lee
6 min readApr 7, 2024

--

Looking for a Postman alternative?

Try APIDog, the Most Customizable Postman Alternative, where you can connect to thousands of APIs right now!

Introduction to the Pokeapi and React.js

The Pokeapi is a free and open-source API that provides a wealth of information about the Pokémon franchise. It offers access to data about Pokémon, moves, abilities, types, and much more. The Pokeapi is widely used by developers to build applications centered around the popular Pokémon universe.

React.js, on the other hand, is a JavaScript library for building user interfaces. It allows developers to create web applications with reusable UI components. React.js has gained significant popularity in recent years due to its efficiency, flexibility, and ease of use.

In this article, we will explore how to leverage the power of React.js and the Pokeapi to build a Pokedex application. A Pokedex is a device in the Pokémon world that provides information about different Pokémon. Our goal is to create a Pokedex app that allows users to search for a Pokémon by name and retrieve various details about it.

Setting up the React app with create-react-app

Before we can dive into building the Pokedex app, we need to set up our React environment. To make the process easier, we will use create-react-app, a tool that sets up a new React project with a basic folder structure and development server.

To install create-react-app, open your terminal and run the following command:

npm install -g create-react-app

Once the installation is complete, navigate to the directory where you want to create your new React project and run the following command:

npx create-react-app pokedex-app

This will create a new folder named “pokedex-app” with all the necessary files and dependencies for our React project.

Next, navigate to the project directory by running:

cd pokedex-app

To start the development server and launch our React app, run the following command:

npm start

This will start the development server and open your app in the browser at http://localhost:3000.

Now that our React app is up and running, let’s clean up the default styling and get ready to build our Pokedex app.

Open the src/App.css file and delete all its content. We'll be adding our own CSS later on.

Next, open the src/index.js file and make the following changes:

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';

ReactDOM.render(
<React.StrictMode>
<App />
</React.StrictMode>,
document.getElementById('root')
);

Save the file, and you should see the changes reflected in your browser. We have successfully set up our React app and made the necessary adjustments to prepare for building our Pokedex app.

Installing and using Axios for API requests

To fetch data from the Pokeapi, we’ll need to make HTTP requests. Axios is a handy package that simplifies the process of making HTTP requests in React.

To install Axios, open your terminal and navigate to your project directory. Run the following command:

npm install axios

After the installation is complete, we can use Axios in our project by importing it into our component files.

Implementing the PokeAPI component

Now it’s time to dive into the implementation of the PokeAPI component. This component will be responsible for fetching Pokémon data from the Pokeapi based on user input and displaying it in our Pokedex app.

Let’s create a new file named PokeAPI.jsx in the src folder and add the following code:

import React, { useState, useEffect } from 'react';
import axios from 'axios';

const PokeAPI = () => {
const [pokemon, setPokemon] = useState('');
const [data, setData] = useState(null);

const fetchData = async () => {
try {
const response = await axios.get(`https://pokeapi.co/api/v2/pokemon/${pokemon}`);
setData(response.data);
} catch (error) {
console.error(error);
setData(null);
}
};

useEffect(() => {
if (pokemon) {
fetchData();
}
}, [pokemon]);

const handleChange = (event) => {
setPokemon(event.target.value.toLowerCase());
};

return (
<div>
<input type="text" onChange={handleChange} value={pokemon} placeholder="Enter Pokemon name" />
{data ? (
<div>
<h2>{data.name}</h2>
<img src={data.sprites.front_default} alt={data.name} />
<p>Type: {data.types[0].type.name}</p>
</div>
) : (
<p>No data to display</p>
)}
</div>
);
};

export default PokeAPI;

In this code snippet, we import the necessary dependencies, including React, useState, useEffect, axios, and we define our PokeAPI component.

Inside the component, we declare two states using the useState hook:

  • The pokemon state stores the user's input, which should be the name of a Pokémon.
  • The data state stores the response data from the Pokeapi.

We define an asynchronous function named fetchData that uses the axios package to make a GET request to the Pokeapi. The URL includes the pokemon variable, which contains the user's input. We await the response and then store the data in our data state or log any errors that occur.

Next, we use the useEffect hook to trigger the fetchData function whenever the pokemon state changes. This ensures that the API is called whenever the user enters a new Pokémon name.

In the render section of the component, we display an input field that allows users to enter a Pokémon name. Whenever the input changes, we call the handleChange function, which updates the pokemon state with the new value.

If the data state is not null, we display the Pokémon's name, image, and type. The values are accessed from the API response using dot notation.

If the data state is null, we display a message indicating that there is no data to display.

Now that we’ve implemented the PokeAPI component, let’s integrate it into our app.

Open the src/App.js file and replace its content with the following code:

import React from 'react';
import PokeAPI from './PokeAPI';

const App = () => {
return (
<div>
<h1>Pokedex</h1>
<PokeAPI />
</div>
);
};

export default App;

In this code snippet, we import our newly created PokeAPI component and render it inside the main App component. We also add a heading “Pokedex” to give our app a title.

Save the file, and you should see the changes reflected in your browser. Our Pokedex app is taking shape, but there is still one more step to complete.

Retrieving and displaying Pokemon data from the API

The Pokeapi provides a wealth of information about Pokémon. Let’s explore some examples of the data that can be retrieved and how to access it.

To fetch data for a specific Pokémon, we need to make a GET request to the appropriate endpoint. For example, to get data for Pikachu, we will use the following endpoint:

https://pokeapi.co/api/v2/pokemon/pikachu

To access specific data fields from the API response, we can use dot notation. For instance, to retrieve the name and sprite URL for Pikachu, we can do the following:

response.data.name // Pikachu
response.data.sprites.front_default // URL to Pikachu's sprite image

Similarly, we can access the Pokémon’s type(s) as follows:

response.data.types[0].type.name // Electric

The API response contains various other fields that can be accessed in a similar manner.

Feel free to explore the Pokeapi documentation to discover more data fields and endpoints: Pokeapi Documentation

With this knowledge, you can now customize the rendering of Pokémon data in your Pokedex app by accessing the desired fields from the API response.

Conclusion

In this tutorial, we explored the amazing world of the Pokeapi and how we can leverage it to build a Pokedex app using React.js. We started by setting up a new React project using create-react-app and learned how to run the development server.

We then installed Axios to make HTTP requests and demonstrated how to fetch data from the Pokeapi using an API endpoint. We also discussed the implementation of the PokeAPI component, which manages state and triggers API calls based on user input.

Lastly, we delved into the data that can be retrieved from the Pokeapi and how to access specific fields in the API response. Armed with this knowledge, you can customize your Pokedex app to display various details about Pokémon.

The full source code for this project is available on GitHub: Pokedex App Repository

Thank you for following along with this tutorial. I hope you found it helpful and enjoyable. Happy coding!

Looking for a Postman alternative?

Try APIDog, the Most Customizable Postman Alternative, where you can connect to thousands of APIs right now!

--

--

Jennie Lee
Jennie Lee

Written by Jennie Lee

Software Testing Blogger, #API Testing

No responses yet