This repository contains real life frontend challenges which you can use to practice frontend! You can use any framework/library to solve these challenges. These are created for the fun and practice purpose to go beyond to-dos.
If you like these challenges, would appreciate getting a star to this repository 🌟
You can also contribute to these challenge lists or share your solutions. We can create a solutions section too for those links!
Here is the list of all challenges -
- Smart Textarea: Twitter like textarea with character count
- Dropdown Component with select/multiselect feature - Similar to React Select
- Autosuggest Input
- Manage cookies pop-up
- Progress Bar
- Scroll and Fix it!
- Password Module
- Multi-step Forms
- Back To Top Button
- Toggle Sidebar
- Copy to clipboard
Twitter like textarea with character count
If you have ever used twitter, you must know your tweet will have a character count limit of 280 characters and once you cross that character limit twitter starts marking your characters with red background and you will see a character count going in a negative value! That's it, that is the task. You can build the same textarea with a customised character count limit.
Features to include in it -
- Create a simple textarea and add necessary styling.
- There should be a customisable character count limit to your textarea.
- Show this limit below the textarea. Improvement - You can add progress circle showing the count.
- If characters go beyond the limit, highlight them, decrease the count to negative value and disable the submit button.
- You can also add warnings when only the 10% character limit is remaining.
- If a user is adding symbols such as
@
or#
made them as a link with relevant href. - After a submit button, display that paragraph.
A component with select/multi select feature, similar to React Select
Dropdowns are part of most applications and they are smart to implement components. React Select is one of those libraries which I heavily trust on for any type of dropdown I need. But while learning if we can create a simple dropdown component, it will have so many benefits over going for the library.
Features to include in it -
- Dropdown component, where list will be open on click of dropdown.
- This list should get closed on clicking the dropdown again, on pressing
esc
key, on clicking outside and after selecting any element. - Enable multi select option as well.
- Search function on type will be a bonus.
We all have tried Google search input. It's pretty cool how it shows you some suggestions based on your typing. We need to create exactly the same. Consider a search location feature, where you are adding names to your city and country. Implement a search feature with a list of cities and countries and show user options based on what the user is typing.
This is one of the most frequently asked questions in the interviews. So that is a bonus point.
Features to include in it -
- A search input with auto suggest option.
- Enable debouncing feature to save excess api calls.
- Use any api or json list to show suggestions
Ever opened a website and saw an annoying pop-up asking to accept cookies or manage your preferences? We need to build that! A custom pop-up component for creating and managing cookies in an application.
Features to include in it -
- After loading a page, a pop-up asking to accept cookies should show up.
- Users should have preferences on accepting all/some or no cookies.
- Same preference should work in your app.
- After 10-15 seconds the pop-up should become hidden with a default state.
Progress bars showing progress of something are commonly seen. Here you can develop 3 types of progress bar
- Progress bar showing page scroll progress, at the top most position of your page.
- Progress bar showing progress as per value passed in percentage.
- Circular variant of same progress bar.
Ever seen a website where you scroll and one of the sections gets fixed at a certain point and the remaining website keeps scrolling? You can see the example here where the products sidebar gets fixed at the left for some time till we scroll the right side section. That is exactly the challenge.
- Implement a section which will be initially somewhere on a webpage.
- After you scroll to that section, the section should get fixed on top and other sections of your site should continue scrolling.
Doesn't it look cool that your password strength and password criteria is getting checked as you type the password? That is the task in this challenge.
Features to include in it -
- Create a password input component.
- Add an eye icon to simply toggle between visible and non-visible states.
- Check the password criteria as the user starts entering the password. You can either mark after every matching criteria or display a message showing which criteria yet to pass.
- Also, find and show the strength of the password based on parameters from criteria it has matched.
Many registration processes need multi-step forms. This is a good use case to maintain data between steps and managing steps transition using javascript. To understand the multistep registration form you can refer to this dribbble shot. Image below
Features to include in it -
- Create a form with 3 different pages.
- Add a transition element on top, which we can use to navigate between three forms.
- Last form should submit the data.
Ever noticed a long webpage with a "Back To Top" button? This makes it easier to go back to the top of the webpage. That's the challange.
Features to include in it -
- Clicking the button scrolls the page to top.
- Make the scroll smooth, instead of suddenly going back to top.
In most of the course webpages, there is a sidebar with chapter names, which can be toggled between show and hide state.
Two examples:
Features to include in it -
- Create a toggle button which should show / hide the sidebar accordingly.
- Sidebar should be fixed. It should not scroll with rest of the page.
Copy to clipboard button is very common either on code heavy websites or for copying links. You need to create a copy to clipboard feature where on clicking the button the content should get copied to your clipboard along with a small pop-up with text copied!
. That's the challange.
Features to include in it -
- Clicking the button text should get copied.
- After copying, a small pop-up should show
copied!
text. - This pop-up should get vanished in 2 seconds with smooth transition.