Build a Backend REST API with Node JS from Scratch
What you'll learn
- Capacity to quickly build a backend API for any kinds of projects and MVPs
- Creating API endpoints, testing property an API call and securing them!
- Capacity to build a client React application and plug it to an API
- HTTP Client Axios package as well as Fetch Native JS API
- Clean Code and Good Coding Practices in NodeJS and RESTful API architecture
- Software Architecture: Learn the n-tier and layered architecture pattern
- Calling an API from the client-side and dealing with CORS from the Web browsers
- Implementing unit tests to the API with AVA test runner
- All the little things you ABSOLUTELY need to know for taking your skills to the next level and becoming an outstanding Web developer
- Implementing several NPM packages such as Pino, Yup, Toastify, React Content Loader, and so on!
- Securing and optimizing an API on production with Rate Limiter, Helmet and Compression
- Documenting an API professionally with JSDoc and OpenAPI
- React Bootstrap v5 (in your React components!)
- Implementing Styled-Components in React components
Requirements
- Basic knowledge of programming (using a code editor, installing Web extensions, ...)
- Basic knowledge of JavaScript and CSS
- A text editor/IDE (Visual Studio Code, WebStorm, IntelliJ, Sublime, ...)
Description
Quickly learn the fundamental of building a robust RESTFul API with NodeJS based on an efficient professional architecture pattern, and then, see how to plug your API with a client which you will also learn how to build. A client built with the latest React and Bootstrap versions.
You will learn how to build a backend API from scratch and build a client that will speak to your API through HTTP protocol.
Communicate with your backend. HTTP and HTTP methods and codes.
How to validate the input data validation.
How to request some API endpoints easily
How to test your API gradually.
How to design a flexible and solid API architecture.
How to secure and optimize your API professionally (with the packages you absolutely need to know).
CORS on your API.
Building a client from scratch with React JS.
Calling the CRUD (Create-Read-Update-Delete) endpoints from your client.
How to document the API endpoints with JSDoc and OpenAPI.
And so much more will be covered in this course.
This JavaScript course will also cover some great packages that will change your life during the development of an API efficiently.
You will learn to create very easily a design in a matter of minutes, without any complicated CSS (just a few reusable components).
You will learn how to embrace your components with Styled-Components and understand the benefits of using it.
You will be able to add as many pages as needed in your React application thanks to React Router Dom.
At the end of this course, you will be comfortable enough to create an API from scratch by yourself, implement new endpoints, being comfortable with many packages (such as logging, rate-limiter, Yup schema validation, ...).
Icing on the cake, you will be confident to create a frontend client from scratch and use those endpoints to interact with the backend on your frontend JavaScript application.
At the end of the course, you will even learn how you can create different unit tests for your API.
Who this course is for:
- Beginners & Intermediates (and any students curious on building such a Web architecture)
- Anyone looking to gain more professional knowledge in JavaScript and NodeJS/React
- Anyone interested in building a clean RESTFul backend API in NodeJS
- Anyone interested in building a modern frontend React JS client
Instructor
Pierre-Henry Soria. A super passionate and enthusiastic software engineer.
Entrepreneur and Web developer for 12 years. I just love it so much!
I've been freelancing for over 5 years and worked in various tech companies and startups around the world (such as the UK, Ireland, New Zealand, Singapore, Australia).
I'm always thirsty to learn and undertake new challenges and eager to share my knowledge with other passionate people, just like you :-)
Happy Coding!