HandleBars Templating in ExpressJS
Handlebars.js is a templating engine similar to the ejs module in node.js, but more powerful and simple to use. It ensures minimum templating and is a logicless engine that keeps the view and the code separated. It can be used with express as the hbs module, available through npm. HandleBars can be used to render web pages to the client side from data on the server-side.
Command to install hbs module:
npm i hbs
To use handlebars in express, we need to store HTML code into a .hbs extension in the ‘views’ folder in the source directory as hbs looks for the pages in the views folder.
The first thing we need to do in index.js file is to require the hbs module
Now, we need to change the default view engine.
In case the views directory is undesirable, you can change the viewpath by the following command:
Now let us create a demo.hbs file in our views directory with the following content:
Now, we render our webpage through express to the local server.
Now, open your browser and type localhost:3000 on web address and verify the webpage at your server.
Now we will see how we can dynamically link the pages to server-side data.
In the index.js, we declare a demo object, in practice, the object can be a result of the request body and/or database query.
Here we send the demo object as a demo to our hbs page. We can retrieve the information in dynamic.hbs present in the views folder.
Rohan is 26 years old
Given multiple values, we can iterate over all of them to perform the same functionality/display for each of the elements.
Let’s take an example, add the following code to your
index.js and run the server and get a response.
where out views/projects.hbs looks something like:
Rahul has the following skills : Data Mining BlockChain Dev node.js