Skip to main content

Express Study Notes: Five Steps To Develop My First Express App


In the last post, I shared my study note about one of the most important reason that Node is very popular is because Node has the largest package ecosystem of open source libraries in the world.

Node's NPM, the package manager for Javascript, contains almost 200,000 packages which are centralized on the NPM website. And more importantly, NPM has a command line tool which help us to install packages really easily.

The course instructor told us that we are going to learn Express.js to develop Apps in this course.

screenshot for the Express.js.com homepage

What is Express.js?

Express.js is a web development framework.

According to the course, framework is a bunch of code that someone else wrote just like a library is except when we use a framework, we have less control.

The goal of using this framework is to make our development of APPs faster.

Why do we use Express.js?

1. It is the most popular Node web development framework so far.
2. It is a very lightweight framework, so it doesn't hide things from us, and it doesn't do things that we don't expect it to do.

Develop First Express APP

Step One: Install Express

We need to open Goormide terminal first. Then, create a directory "FirstExpressApp" by using "mkdir" command. Then, we create a new Javascript file "App.js" in this folder.

In order to install express, we need to type "npm install express", and the syntax will find the Express.js package and install for us. As installation is done, we can see the "express" folder on the left menu bar.


Step Two: Create The First Route

Open the "App.js" file, we need to write the code to require "express" first. Then, we can start to develop our App.

The App is very simple. Basically, when it get slash request, we receive "Hello" message; when it get slash bye, we receive " Goodbye!" message; and when it get slash cat, we receive "MEOW!".

In order to let the App run, we need to write route. Route is how we listen for a particular requests and then run some code depending on the request we get.

In this project, we have three different routes. All we need to start with: 

app.get("/", function(req, res){
res.send("message");})

According to the course, app.get takes two different parameters:

(1) The URL or the path, which is "/"
(2) A callback function to run this code. 

The callback function takes two arguments: request (req) and response (res).

"res.send()" is a way of responding with some text.

Step Three: Run The Code in Node.js

I finish the rest two routes by using the same function. The only changes are the message. 

Even though we have all the app code done, we still can't run because we need to add an app listener.

   app.listen(3000, process.env.PORT, process.env.IP)

This code will tell Express.js to listen on a particular port that the server wants to and a particular IP that this server expects to.

Then, we save the file and type "node app.js" in the terminal to run the code. By the way, every time you add new route, you have to restart the node app.js.


Step Four: Find The Specific URL

In the Node, we can't actually see the app result. We need to find a specific url from Goormide Project "Running URL and Port".  



Step Five: Run The URL on Browser To Test App

We paste this URL on the browser, and hit enter. You can see the first message "Hello!".


When we add "/bye" on the link, it shows "Goodbye!".


When we change the slash to "/cat", it shows "MEOW!".




Comments

Popular posts from this blog

Intermediate Express.js: How To Add Styles & Partials in EJS File?

So far, we only have simple HTML tags and ejs tags in each ejs file. Every template page has no style at all. And the basic HTML header and footer are also missing. Today, I learned how to add styles and partials in ejs file. Link Style Step One: Touch a Separate CSS file I create a new directory "Style" under the "EJSDemo" directory, then I add a new CSS file "app.css" inside "Style" folder. Step Two: Add app.use(express.static()) in the app.js I add app.use(express.static("style")) in the "app.js". This will tell Express.js to serve the content of "Style" directory. Step Three: Write styles in CSS file I simple give body an orange background color and set text color to be grey. Step Four: Link to CSS file in the EJS file I just add <link> tag to link the "app.css" file on the top of the h1 tag in each ejs template. As the result, when I run the app and...

Seven Most Common jQuery Methods Last Part: ADD/REMOVE/TOGGLE CLASS()

Add, remove and toggleClass is also a very common way to manipulate style. .addClass() and .removeClass() I add two class selector in the style tag. Class one is to change text color to be green, and class two is change both text and background color.  Now I refresh the page and change h1 text to green by using addClass() method: $("h1").addClass("one") .  If you want to remove the style, you can change it to removeClass("one"). I do the same thing to the list. I change the list color and add a background color by adding the class two style value: $("li").addClass("two") . .toggleClass()  According to jQuery, toggerClass method can add or remove one or more classes from each element in the set of matched elements, depending on either the class's presence or the value of the state argument. I only want to change the first list item color and background by writing: $("li").first().toggleClas...

Intro to Backend: Is Browser The Only Place To Send HTTP Request?

Today,  I begin to learn the second part of web develop course: backend. Frontend is the stuff that we can see and interactive with, such as HTML, CSS, and JS. We can type our code, style our page, or write some function to make interaction. However, backend is everything else. For example, we type Target web address in the Internet Browser. As we hit "enter", there are a few steps to go through: 1. The HTTP request is sent to a particular server's IP address. 2. The server figures out what to send us 3. It sends a HTTP response back to us Those process we are hard to see, and it happens in less than one second. The instructor said that the browser is not the only place to send the HTTP request, and there are so many choices out there. In this learning course, we are going to use Postman App . Postman allows us to make HTTP requests and viewer responses. It is really for developers to understand how things are working or debug something. In the P...