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

My Story: A Mommy Start To Learn Code From Zero

From Google Image I am not a programmer, and I thought I would never become one. Everytime I see someone is coding, I think he or she must be very talent.  For me, coding is a very difficult subject to learn. Not only the language has so many rules, but also the logical reasoning behind the language is complex.  In my graduated school, I knew many friends who didn't have any coding background, but they are doing programmer or developer jobs now. Some of them went to school to study coding, and some of them  learned to code by themselves. Their stories are so impressive.  I wasn't ready to learn code until I finished my first Chinese book "留学,我的青春呀!" recently. I always want to be a writer and write my own book. I started writing blog three years ago, and I updated my post two to three times every week. As I enjoyed writing , I started to get some followers, likes, and good comments on my blog. Then, I decided to plan my first book. My First...

Three Most Common HTML Form Elements You Should Know

When I visited the Facebook page at the first time, it required me to sign up. Therefore, I completed the sign up form to create my new account. The form is very simple to fill in because it only asks for very common information such as full name, phone number, new password, birthday, and gender. It only took me one or two minutes to finish the form. Not only Social media sites require us to sign up first before we post anything, but many business or eCommerce sites also ask us to create new account before we take any action. For example, when I go to the Origins skin care site, it will pop up a email sign up form window. To encourage new customers to sign up, it gives a 15% off for the first order. It is definitely an attractive call-to-action message. Anyway, if your website requires users to sign up, you need to know how to create a HTML form. Yesterday, I just learned how to build a simple HTML form from Udemy course. And it is not that hard. All you need to kno...