These are the topics for week 1:
- What is React.js?
- What React is not
- Componentization
- HTML in JS: JSX
- State & Props
- Hooks
- useState
- useEffect
- Forms: Controlled vs Uncontrolled
- Tools
- React dev tools
create-react-app
command- Static hosting
In the React world there is a huge shift happening since the introduction of 'hooks' in 2018. Before hooks React was built using both class and function components. Currently it is recommended to use only function components in combination with hooks for all of the code you build from now on. When you are going to do research on your own or when you get into your internship you are going to run into class components however. This will be less and less as time goes on and hopefully we can remove this at some point in the future.
We at HackYourFuture will only be teaching you the recommended way of building applications and have provided a section in the study book to share the most basic details on how to read class components here. If you encounter class components in your research, try to look for a more up to date tutorial, question, or video. If you encounter class components during your internship, then convert it to a function component. The developers will love you :).
This week we will start the wonderful journey of React! Let's start by learning what React is and more importantly what it is not, once you start working with big frameworks like this it becomes hard to identify where the boundary is and we want to make sure you understand where React ends and where JavaScript begins. Have a look at our introduction to React here.
React is a big framework that introduces a lot of new terminology and ways of thinking to simplify the building of bigger applications. Let's start by learning about State and Props here. Now let's go into the basic hooks that React gives you to build your application here. For now it is best to focus on the useState
and useEffect
as they are the ones you will use a lot, but you can already have a look at the others to have them in your mind. The last thing we want you to have a look at is how to work with user input (as websites will always need to respond to user input). For that we are actually going to go into a discussion about controlled vs uncontrolled components. This is a little broader topic, but forms and user input is the best example for this. Have a look here and make sure that you always use the controlled way of writing forms in your applications.
Phew, that was a lot, but you now have knowledge of the basic building blocks with which you can already create some very cool applications. But how do you start?
Let's look at some tools that will allow you to start quickly (create-react-app) as well as easily deploy anything you build to the web (static hosting).
To bring it all together, you can follow Shriyans in the following video who will use all of this information to build a small application. You can stop the video at 35 minutes, the homework has changed since then.
Are you finished with going through the materials? High five! If you feel ready to get practical, click here.