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

Intermediate CSS: Three Steps To Create A Photo Gallery

I have seen many image blogs these years. People love to post their photos online to express life and feeling.  Image is powerful because it could bring a visual story to audience. People can see what you see, and may be feel the same way as you feel, too. If we want to build our own photo gallery, what should we do? Luckily, the boot-camp instructor just showed me how to use HTML and CSS to create a simple photo gallery.  I would love to share my study note here. (p.s. all the image links are provided by Udemy course instructor) Step One: Add Image Links on HTMLPage The instructor provides all the image links. All we need to do is add those links inside the <img> tag. Without CSS, the page will looks like this: they are not organized, and sizes are different, too. Step Two: Set Image Property Values We set the width of each photo the same value which is 30%, so there will be three images per line. The percentage value can help...