Skip to main content

Intermediate Express.Js: Write Conditions and Loops In The EJS (study note)


We continue to use the app.js which we have build to be the study example. In the last post, we only add a simple EJS tag <%= thingVar %> inside h1 tag. This will match the "thing" to any "thing" request from the user.

If Statement

Today, the course shows us to write a simple if statement in the EJS file. I learn to apply it to my own app.

In the if statement, if users send"/wantto/workout" request, the page will show a new content "Good Idea!".


We wrote the if statement in the "diet.ejs" file, and we add "<% %>" tags around the code. We have to wrap every line of JavaScript anytime JavaScript starts and ends.

Moreover, you may see there are two types of ejs tags here:
  • <%= %>

The one with equal sign. According to the course, when we add equal sign, the value that is returned inside of the tag will be rendered to the HTML page. it will be added to the HTML. For example, if we write <%= 10+10 %>, it will be ended up 20 in the HTML page.

  • <% %>
When we are doing logic like if statement or loops, we don't want something to be added to HTML. The logic is not supposed to display anything, so we don't use equal sign.

As the result, when we run the app, we can see "Diet Idea: workout" is equal to the "/wantto/workout" on the browser. And the page shows "Good Idea!" because the logic we set up.



For Loop

We can also write loops in the ejs file. In order to do that, we start to add a new route in the "app.js" file.

In this new route, we want to show post page when users send a "/posts" request. In the post page, it has some post titles with authors.

This route will render the new ejs file "workoutposts.ejs", and we also add {posts: posts} in side the res.render(). The first "posts" is inside the template, and the second "posts" refers to the name of variable.


Then we create a new ejs file "workoutposts.ejs".  In this file, we write a simple h1 "Workout Posts", and a for loop, which we make li for each post. 


We also need to pay attention on the ejs tags. For the for loop statement, we use "<% %>" because it is the logic. For the JavaScript inside the li, we use "<%= %>", because we want it returns the post content on the HTML page.

As the result, when I search "/posts" on the browser, it shows the list of each post title and author name in bold.

Now we have one file that is responding not only in different way depending on the variables that users pass in, but also depending on what the variables is equal to.

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...

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...

Seven RESTful Routes You Should Know!

I have been followed the course to develop several app projects. They all follow the RESTful route pattern. Today, I learned many key points about RESTful and would like to share my study note here. What Is REST? REST stands for representational state transfer. I don't know what does this mean, but it is not important right now. You just need to know that REST is just a pattern for defining our routes. What's The Point Of REST? The important things for us is to define what REST is. REST is a way of mapping HTTP routes and CRUD functionality together. By the way CRUD stands for Create, Read, Update, and Destroy. The point of REST is that we don't do whatever we want. Instead, we follow a pattern. It is also more reliable so that if we are interacting with a restful API, it follows a particular pattern. Seven RESTful Routes The course lists the seven route table. It just acts as a pattern that we can fill in the blanks when we develop our own App. screen...