React Hooks & GraphQL Apollo Tutorial: Build a First Example App in 4 Easy Steps
In this post we will give you information about React Hooks & GraphQL Apollo Tutorial: Build a First Example App in 4 Easy Steps. Hear we will give you detail about React Hooks & GraphQL Apollo Tutorial: Build a First Example App in 4 Easy StepsAnd how to use it also give you demo for it if it is necessary.
In this tutorial, we’ll learn how to build a React application in four easy steps with React Hooks and GraphQL Apollo for consuming a third-party API. we’ll learn how to:
- Set up a development environment for React development,
- Initialize a React project,
- Use React Hooks,
- Consume a GraphQL API,
- Building the final production bundles so you can deploy them to the cloud
We’ll be consuming a third-party GraphQL API available from this URL
We’ll build our application in four easy and clear steps as follows:
- Step 1 – Setting up a development environment
- Step 2 – Creating your first React project
- Step 3 – Consuming and rendering the GraphQL API
- Step 4 – Building the React application
Prerequisites
Before diving into the actual steps, let’s first see the prerequisites that you will need to have in order to follow this tutorial:
- You will need to have Node.JS and NPM installed on your machine,
- You need to be familiar with modern JavaScript and ES6+ features.
If you don’t have Node installed, you can download the installers from the official website or you can also use NVM, a POSIX-compliant bash script to install and manage multiple active versions of Node in your system.
Note: You may be thincking, Node is required for building server-side apps but we are here building a front-end app so why do we need it? Simply because most front-end libraries nowadays have CLI (Command-line Interfaces) tools to easily scaffold and work with projects including React. These tools are built on top of Node.js. We need to have Node and NPM to install and run the
create-react-apptool.
Now that we have seen the prerequisites of our tutorial, let’s start with the first step.
In this first step, we’ll start by setting up a development environment for building our first React application.
Since, as stated in the prerequisites, Node and NPM should have been already installed on your machine we only need to install the create-react-app tool to set up our development environment.
The create-react-app utility is the official tool for initializing and working (serving and building etc.) with React projects.
Head over to a new command-line interface and run the npm install command as follows:
$ npm install -g create-react-appNote: Depending on your operating system and npm configuration, You may get EACCESS errors when installing the tool globally. In this case, you can simply add
sudobefore your command in Linux and macOS, or use a command prompt with the administrator rights in Windows. You can also simply fix your npm permissions.
As the time of working in this tutorial, create-react-app v3.1.1 was installed.
That’s all for this step, we are ready for creating a new React project.
Step 2 – Initializing a New React Project
In the second step, we’ll initialize a new React project.
Head over to your command-line interface and execute the following command:
$ create-react-app react-graphql-appWait for create-react-app to generate the project’s files and install the required dependencies from npm and then run the following commands to serve the application locally using a development server:
$ cd react-graphql-app$ npm startThe development server will be available from the http://localhost:3000 address.
This is a screenshot of our React application running inside a web browser:

Now that we hava initialized our React application and served it using a local server that has support for live-reload, let’s start coding!
Step 3 – Consuming and rendering the GraphQL API
In this third step, we’ll see how to consume our GraphQL API using the Apollo client. But what’s Apollo client?
It is a GraphQL client that provides many advanced features such as intelligent caching that makes it a single source of truth for the local and remote data in your application.
These are the required libraries for setting up Apollo:
To set up Apollo and add GraphQL support in our application we’ll need to install a few libraries from npm.
Open a new command-line interface and run the following commands:
$ npm install graphql --save $ npm install graphql-tag --save$ npm install apollo-client --save $ npm install apollo-link-http --save $ npm install apollo-cache-inmemory --save $ npm install react-apollo --save We first installed graphql which provides the GraphQL implementation for JavaScript, next graphql-tag which provides a set of useful utilities that we’ll be working with in our app. Next we installed the apollo client alongside its in-memory cache and HTTP link modules, finally we installed the Apollo bindings for React.
Now, let’s use the GraphQL client in our app.
Open the src/index.js file in your React project and add the following imports:
import{ApolloClient}from'apollo-client';import{InMemoryCache}from'apollo-cache-inmemory';import{HttpLink}from'apollo-link-http';We imported the Apollo client, in-memory cache and HTTP link modules.
Next, create in-memory cache and the HTTP link instances as follows
constinmemoryCache=newInMemoryCache();consthttpLink=newHttpLink({uri:'https://graphql-pokemon.now.sh/'})The HTTP link allows us to send HTTP requests to the GraphQL API.
Finally, create the Apollo client instance as follows:
constapolloClient=newApolloClient({inmemoryCache,httpLink})Now we have an instance of Apollo client linked to the in-memory cache and HTTP link instances.
What is left is to connect the Apollo client with our React component(s) using ApolloProvider.
Go to the src/index.js file and import ApolloProvider as follows:
import{ApolloProvider}from'@apollo/react-hooks';Next, wrap the App component with ApolloProvider as follows:
/* [...] */ReactDOM.render(<ApolloProviderclient={client}><App/></ApolloProvider>, document.getElementById('root'));Now, how to send a GraphQL query to the API?
Apollo provides a React hook that makes it easy to call GraphQL operations from the UI components.
Go to the src/App.js file and import useQuery and gql as follows:
import{useQuery}from'@apollo/react-hooks';importgqlfrom"graphql-tag";The gql tag allows you to wrap GraphQL queries.
The useQuery hook exposes the error, loading and data properties from a result object.
Next, add the following example GraphQL query in the src/App.js file:
constGRAPHQL_QUERY=gql'{pokemons(first:100){idnumbername,image}}This query will allow you to get the first 100 pokémons with their id, number, name, and image.
Next, send the GraphQL query with the useQuery hook as follows:
functionApp(){const{data,loading,error}=useQuery(GRAPHQL_QUERY);if(loading)return<p>Stillloading..</p>;if(error)return<p>Thereisanerror!</p>;We simply destructure the object returned from the useQuery() hook to get the data, loading and error attributes.
When loading equals true i.e when data is still being received, the App component will render Still loading...
If there is an error the component will render There is an error!.
Otherwise we’ll have our data in the data variable which we can render as follows:
return(<React.Fragment><divclassName="container">{data&&data.pokemons&&data.pokemons.map((pokemon,index)=>(<divkey={index}><imgsrc={pokemon.image}/><div><h3>{pokemon.name}</h3></div></div>))}</div></React.Fragment>);That’s it, we have set up the GraphQL client in our application and sent a query to fetch data from our API then rendered data in our React component.
Step 4 – Building the React Application
In this final step, we’ll proceed to build our React application.
Simpy to your command-line interface and run the followng command from the root of your React project:
$ npm run buildThis will generate a production-ready bundle inside the build folder of your project that you can deploy to your cloud server.
Conclusion
As a recap of our tutorial. We have learned in four easy steps how to create a React application and fetch data from a GraphQL API and display it in our component then finally build the app for production.
Hope this code and post will helped you for implement React Hooks & GraphQL Apollo Tutorial: Build a First Example App in 4 Easy Steps. if you need any help or any feedback give it in comment section or you have good idea about this post you can give it comment section. Your comment will help us for help you more and improve us. we will give you this type of more interesting post in featured also so, For more interesting post and code Keep reading our blogs
