In this lecture we talk about Node.
HTTP stands for Hyper Text Transfer Protocol and it is the protocol we follow when making requests and receiving responses from a client to a server.
This is usually a personal computer that talks to a server through the internet.
The client is also known as the front-end
part of our application.
We will be using React
for our front-end.
This is usually a computer that has clients that will talk to to request information from.
The server is also known as the back-end
of the application.
We will be building our servers with Node
.
Node is a javascript runtime environment
.
Javascript has been around since 1995 and for a while it was only used inside of a browser environment, meaning that was the only place we could use it.
This meant that developers were having to code in multiple languages to create a front-end and back-end to their applications.
When Node came out, it allowed developers to write Javascript code that runs directly on the computer process itself, rather than being confined to a browser environment. This means that Node can be used to write server-side applications that have full access to the operating system, file system, etc.
Node was written in C
, C++
, and Javascript
. It was built on top of the V8 Javascript
engine. This is the same engine that browsers like Google Chrome
use.
We can run node in the Terminal by typing the command:
$ node
This will turn the terminal into an interactive javascript environment.
We can also execute a JS file by running the terminal command
$ node "name of file to execute"
It's important to keep note that this works similar to REPL
where only the last item will be returned, unless we are to console.log values.
We can use nodemon
to constantly watch our file to execute it when theres a resfresh.
Install nodemon globally:
$ npm install -g nodemon
Run nodemon
on a file instead of node
.
NPM stands for Node Package Manager
.
This is where we can get access to a bunch of great libraries to use inside of our code.
To use it we just need to have node
installed onto our machine and then we need to initialize our applicaiton to use it.
When in the project directory, run the terminal command:
$ npm init -y
This command will initialize a package.json
file for us so we can install packages from npm
into our project.
This file will look something like this:
{
"name": "node-one",
"version": "1.0.0",
"description": "In this lecture we talk about Node.",
"main": "index.js",
"dependencies": {},
"devDependencies": {},
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1"
},
"keywords": [],
"author": "",
"license": "ISC"
}
One of the primary uses of Node is to act as a server
.
A server will receive a request then perform some logic and return a response.
Express
is the most popular framework we can use to build a server with node.
It will make it easier to matchup HTTP methods to by using endpoints
to control what data a front end application can send and ask for.
First we need to install express into our project to use it.
$ npm install express
REFER TO THE serverSetup.js
FILE FOR MORE INFORMATION ABOUT SETTING UP EXPRESS
Endpoints are what we use to create a way for a front end application to make requests to our server.
To create an endpoint, we will use the object returned from express()
. This object will have the methods we can use to receieve specific RESTful Requests
.
Let's look at the syntax for one:
app.get('/api/users', handlerFunc);
The endpoint is comprised of three parts:
The Method: - this is where we declare what type of request we are expecting. For example: get
, post
, put
, delete
.
The Path - this is easy to think about as an entrance to our server or a "gate".
The Handler Function - the handler function is the function that will be executed when a request hits this end point.
Handler Functions
are the functions that we use to handle a request that is made to our server.
This function receives two objects as default arguments. These objects are the request
and response
object.
app.get('/api/users', (req, res) => {
// logic here to handle the req
})
Note: req will always be before res
The req
object is an object that will contain information about the incoming request. This where we can access information from the query
, and the params
of the request.
req.params
This is the object that we can use to get the data from the params of a request.
We declare the param variable to use in the path
of our endpoint. We will prefix the param with a colon.
app.get('/api/users/:id, (req, res) => {
// we can access what ever info is sent through the id param
console.log(req.params.id)
});
Using the colon is like telling javascript to treat it as a placeholder, and whatever is sent through we can access it on the req.params
object.
req.query
This is the object that we can use to get data from the queries of a request.
We will not add any extra information to our path
when using a query, unlike params.
// front end request w/ query
axios.get('/api/users/?name=tayte)
// back end endpoint
app.get('/api/users', (req, res) => {
// notice how we dont set anything special in our path
// we can access the name tayte from the query using the query obj
console.log(req.query.name) // this will log tayte
})
The res
object is an object that we will use to set information about the response and send it back.
This object will have built in methods that we can use to add information to the response that we will send back.
res.send()
is a function that we can use so whatever is passed in as an argument to the function will be sent back as the response
.
res.send('Hello');
Above, we are sending a string of hello back. This is what will fill the response.data
object on the front end.
We can set custom status codes for the response by using the .status()
method before we send back a response. We will pass in the status code that we want this end point to respond with.
res.status(200).send(users);