Build a paginated Pokemons list with a "Load more" button - starting from failing unit tests!
data:image/s3,"s3://crabby-images/7bef9/7bef9f99c128ea0b17e12a31ce84712b4e5e96f9" alt="Build a paginated Pokemons list with a "Load more" button - starting from failing unit tests!"
It's common to see websites or applications that show lists of data with a "Load more" button.
Usually, the page initially shows just 10-15 results and if the user presses "Load more", more results are loaded and merged into the initial set.
Some examples are the IKEA website or the H&M online shop!
data:image/s3,"s3://crabby-images/bcd7a/bcd7acfa59abd4b1b39783ded7168bef0da77e05" alt=""
data:image/s3,"s3://crabby-images/5e4ba/5e4ba4c5ba7a2cce3a2796bfdd3492bf881e9595" alt=""
data:image/s3,"s3://crabby-images/78b29/78b29eb9397e17b9a42ca8d09b7d94c4c763138b" alt=""
However, their APIs are not free, so let's use the Pokemon API instead to build something similar. Here's an example from the Pokedex website that uses the same pattern, with a "Load more" button:
data:image/s3,"s3://crabby-images/e29a6/e29a69270df5affb8130efbb85e5f7d92a25944b" alt=""
Build a component that displays a list of Pokemons with a "Load more" button. You can use the free Poke API to retrieve the data.
- Initially, the component should only show the first 5 items
- Below the list, there should be a label saying how many items are being displayed from the total - e.g. "Displaying 20 of 567 results"
- Clicking "Load more" will load another 5 items into the list
- When the are no more results, the button should no longer be displayed
The styling doesn't matter for this component - just make sure to display the pokemons as <li>
elements in a list - <ul>
- and show the name for each:
data:image/s3,"s3://crabby-images/fc8d8/fc8d85d0b508b709b99a421bdca60fe7f911f279" alt=""
To get started, you can clone this repository . It contains the scaffolding for the component and some failing unit tests:
data:image/s3,"s3://crabby-images/a730a/a730a06c8d04c3c32317253a91651714696a1998" alt=""
Your job will be to implement the pokemon-list.jsx
component and get the tests to pass.
The tests are mocking the real API using msw. If you want to learn more about how this works, this is a great walkthrough.
data:image/s3,"s3://crabby-images/fb61f/fb61f16d32dfeef7e93bbc9341b79ad101aaefbf" alt=""
To check your work, run the tests with npm run test
and/or playing with the component by running the app with npm start
.
Enjoy the challenge!
And don't hesitate to ask any questions or give feedback in the comments below.
Good luck! 🍀
Member discussion