Skip to main content

Creating a Joke Application in React

Introduction

I've recently started learning React. I've been a backend developer for a long time, but have started to love doing client side work. As they say, the best way to learn is to practise. So here is a simple joke application that I've written in React. The source code for the application can be found on GitHub at: https://github.com/doobrie/react-joke

joke.png

Creating the project

Whilst practising, I've quite often created projects from scratch, but this is quite tedious as the same steps need to be taken for each project. I needed to create the project structure, configure Babel, write some control scripts etc. Instead of doing that this time, I've used the create-react-app tool to scaffold the basics of an application.

npx create-react-app

This sets up everything that you need to get started with a React app.

Coding

As this is a simple project, I've created one react component, function app(). I've created this as a functional component rather than a class as there's very little to it, and no particular need to write a class.

First of all, I wrote the JSX for the app.

  return (
    <div className="app">
      <header className="app-header">
        <h1>Jokes</h1>
      </header>
      <section className="app-content">
        <p>{joke}</p>
      </section>
      <section>
        <button
          onClick={refresh}
          disabled={joke.length === 0}
        >
          Ha ha.  Tell me more
        </button>
      </section>
    </div >
  );
There's very little to this, but the important things to notice are:

  • The joke that is to be displayed is rendered via {joke}. This variable will be stored within the state of the application.
  • Storing the joke within state, allows me to disable the refresh button if there is no joke. This will be when the application is fetching a joke from a remote api.
  • A button invokes a refresh mothod when clicked which will fetch a new joke and store it in the application's state.

Application State

As mentioned above, I'm storing the joke in the application's state. This is achieved using the React hook:

const [joke, setJoke] = useState('');

Creating the logic

To get the joke, I'm making a call to the https://icanhazdadjoke.com endpoint. This returns JSON data containing a random joke.

To call this, I use Axios to call the endpoint and then store the joke in the application's state.

Axios needed to be added to the project before using it. This was achieved using yarn

yarn add axios

The code to get the joke looks like this:

  const refresh = () => {
    setJoke('');
    axios.get('https://icanhazdadjoke.com/', {
      headers: {
        Accept: 'application/json',
      }
    })
      .then(res => {
        setJoke(res.data.joke);
      })
  };

Finally, I want to make sure that the state (and therefore the joke to display) is updated when the application first runs. I do this with the useEffect hook.

  useEffect(() => {
    refresh();
  }, []);
 

The final stage was to add some styling to the application. This is stored in the App.css file which you can see in the project's GitHub repo.

To run the application, I'm using yarn start

Conclusion

This is a very straightforward app, but I've found it useful when practising React, and I hope you find it useful too. The full code for the application is available on GitHub at: https://github.com/doobrie/react-joke

Credits

Photo by Marija Zaric on Unsplash

Comments

Popular posts from this blog

Changing Default Search Provider in Firefox on Linux Mint

On Linux Mint, the default version of Firefox is installed and configured to allow the following search engines to be queried directly from the address bar: Yahoo! Startpage DuckDuckGo Wikipedia Mint defines these as the default available set of search engines based upon 3 criteria (funding to Linux Mint, privacy support and whether the search engine is non-commercial). Other search engines such as Google, Bing or Twitter, etc. can easily be added into the default version of Firefox however. To add a different search provider, browse to Search Engines At the bottom of the page, click on the icon of the requested search engine, then click on the ... button in the URL bar and select the Add Search Engine option. You then have the option to change the default search engine within Firefox preferences to your new choice.

The new Eclipse logo

In a blog post today, Ian Skerrett has announced the new logo for Eclipse. Last fall we [The Eclipse Foundation] started a process to  update the Eclipse logo . The existing logo had not been change since Eclipse was launched and it was showing its age. I am happy to announce we have finished the process and am pleased to introduce the updated Eclipse logo. The new logo has a fresh modern look to it, which I think is a good improvement and will stand Eclipse in good stead for the future. The new logo will be included with the next Eclipse release train, Luna, and gradually rolled out across the Eclipse site and projects. What do you think?  Do you like the new logo?  Add your comments below.