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

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

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