Here’s a formal definition as given on the official Node.js website:
Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient.
Node.js’ package ecosystem, npm, is the largest ecosystem of open source libraries in the world.
I/O refers to input/output. It can be anything ranging from reading/writing local files to making an HTTP request to an API.
I/O takes time and hence blocks other functions.
Consider a scenario where we request a backend database for the details of user1 and user2 and then print them on the screen/console. The response to this request takes time, but both of the user data requests can be carried out independently and at the same time.
Blocking I/O (left) vs Non-Blocking I/O (right)
In the blocking method, user2’s data request is not initiated until user1’s data is printed to the screen.
That’s where the non-blocking part comes in.
On the other hand, using a non-blocking request, you can initiate a data request for user2 without waiting for the response to the request for user1. You can initiate both requests in parallel.
This non-blocking I/O eliminates the need for multi-threading since the server can handle multiple requests at the same time.
If you have 26 minutes, watch this excellent video explanation of the Node Event Loop:
Image Credits: Andrew Mead’s course
- Push main() onto the call stack.
- Push console.log() onto the call stack. This then runs right away and gets popped.
- Push setTimeout(2000) onto the stack. setTimeout(2000) is a Node API. When we call it, we register the event-callback pair. The event will wait 2000 milliseconds, then callback is the function.
- After registering it in the APIs, setTimeout(2000) gets popped from the call stack.
- Now the second setTimeout(0) gets registered in the same way. We now have two Node APIs waiting to execute.
- After waiting for 0 seconds, setTimeout(0) gets moved to the callback queue, and the same thing happens with setTimeout(2000).
- In the callback queue, the functions wait for the call stack to be empty, because only one statement can execute a time. This is taken care of by the event loop.
- The last console.log() runs, and the main() gets popped from the call stack.
- The event loop sees that the call stack is empty and the callback queue is not empty. So it moves the callbacks (in a first-in-first-out order) to the call stack for execution.
These are libraries built by the awesome community which will solve most of your generic problems. npm (Node package manager) has packages you can use in your apps to make your development faster and efficient.
Require does three things:
- It loads modules that come bundled with Node.js like file system and HTTP from the Node.js API .
- It loads third-party libraries like Express and Mongoose that you install from npm.
- It lets you require your own files and modularize the project.
Require is a function, and it accepts a parameter “path” and returns module.exports.
A Node module is a reusable block of code whose existence does not accidentally impact other code.
You can write your own modules and use it in various application. Node.js has a set of built-in modules which you can use without any further installation.
V8 is an open source runtime engine written in C++.
Something that has happened in our app that we can respond to. There are two types of events in Node.
- System Events: C++ core from a library called libuv. (For example, finished reading a file).
Writing Hello World in Node.js
We have to do this, don’t we?
Make a file app.js and add the following to it.
Open your node terminal, change the directory to the folder where the file is saved and run node app.js.
Bam — you’ve just written Hello World in Node.js.
There are a ton of resources you can use learn more about Node.js, including freeCodeCamp.org.