Devahoy Logo
PublishedAt

NodeJS

Node Template Engine

Node Template Engine

วันนี้ขอนำเสนอบทความสั้นๆสำหรับการเลือก Template Engine บน Node.js หากท่านยัง render ไฟล์ html ธรรมดาอยู่แล้วละก็ เปลี่ยนมาใช้ Template Engine กันดีกว่าครับ บทความนี้ assume ว่าผู้อ่านมีความรู้พื้นฐาน Node.js รวมถึง Express.js เบื้องต้นอยู่แล้ว เพราะฉะนั้นตรงส่วนไหนไม่เข้าใจ ก็ไปอ่านเพิ่มเติมเอานะครับ ขอโฟกัสที่ตัว Template Engine อย่างเดียว

Setup Project

ตัวอย่างจะทำการสร้างโปรเจ็คขึ้นมาแบบธรรมดา โดยมีแค่ไฟล์ package.json, app.js และโฟลเดอร์ views โดยภายในโฟลเดอร์นี้ก็จะเป็นไฟล์ template นามสกุลต่างๆ

ไฟล์ package.json

1
{
2
"name": "simple-template-engines",
3
"version": "0.0.1",
4
"dependencies": {
5
"ejs": "^2.3.3",
6
"express": "^4.13.1",
7
"express-handlebars": "^2.0.1",
8
"jade": "^1.11.0",
9
"swig": "^1.4.2"
10
}
11
}

ไฟล์ app.js

1
var express = require('express')
2
var path = require('path')
3
4
var app = express()
5
6
app.set('views', path.join(__dirname, 'views'))
7
// Setup template engines go here.
8
9
app.get('/', function (req, res) {
10
// code goes here
11
})
12
13
app.listen(8000, function () {
14
console.log('App running on port 8000')
15
})

Jade Template

1
npm install jade

การใช้งานก็แค่ set view engine เป็น jade

ไฟล์ app.js

1
app.set('view engine', 'jade')
2
3
app.get('/jade', function (req, res) {
4
res.render('index', {
5
title: 'This is title of Jade Template',
6
message: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit',
7
names: ['John Doe', 'Jane Doe', 'Jane Dane']
8
})
9
})

สร้างไฟล์ index.jade ในโฟลเดอร์ views

1
h1 #{title}
2
p #{message}
3
ul
4
each name in names
5
li= name

เมื่อรัน Server ก็จะถูกคอมไฟล์เป็นไฟล์ html แบบนี้

1
<h1>This is title of Jade Template</h1>
2
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit</p>
3
<ul>
4
<li>John Doe</li>
5
<li>Jane Doe</li>
6
<li>Jane Dane</li>
7
</ul>

EJS Template

1
npm install ejs

การใช้งานคล้ายกับ Jade ก็แค่ set view engine เป็น ejs

ไฟล์ app.js

1
app.set('view engine', 'ejs')
2
3
app.get('/ejs', function (req, res) {
4
res.render('index', {
5
title: 'This is title of EJS Template',
6
message: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit',
7
names: ['John Doe', 'Jane Doe', 'Jane Dane']
8
})
9
})

และสร้างไฟล์ index.ejs ขึ้นมาสำหรับเอาไว้ render

1
<h1><%= title %></h1>
2
<p><%= message %></p>
3
<ul>
4
<% names.forEach(function(name) { %>
5
<li><%= name %></li>
6
<% }); %>
7
</ul>

เมื่อรัน Server ก็จะถูกคอมไฟล์เป็นไฟล์ html แบบเดียวกับ Jade แบบนี้

1
<h1>This is title of EJS Template</h1>
2
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit</p>
3
<ul>
4
<li>John Doe</li>
5
<li>Jane Doe</li>
6
<li>Jane Dane</li>
7
</ul>

Swig Template

1
npm install swig

Swig จะต่างจาก Jade และ EJS เล็กน้อย คือไฟล์ extension จะเป็น html ปกติ โดยเรา้ต้องการให้ไฟล์ html ไหนทำการ render ด้วย Swig ก็จะใช้คำสั่ง swig.renderFile ฉะนั้น view engine ก็เซตเป็น html แบบนี้

1
var swig = require('swig')
2
3
app.engine('html', swig.renderFile)
4
app.set('view engine', 'html')
5
6
app.get('/swig', function (req, res) {
7
res.render('index', {
8
title: 'This is title of Swig Template',
9
message: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit',
10
names: ['John Doe', 'Jane Doe', 'Jane Dane']
11
})
12
})

ไฟล์ index.html สำหรับ Swig Template

1
<h1>{{ title }}</h1>
2
<p>{{ message }}</p>
3
<ul>
4
{% for name in names %}
5
<li>{{ name }}</li>
6
{% endfor %}
7
</ul>

เมื่อรัน Server ก็จะถูกคอมไฟล์เป็นไฟล์ html แบบเดียวกับ Jade และ EJS แบบนี้

1
<h1>This is title of Swig Template</h1>
2
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit</p>
3
<ul>
4
<li>John Doe</li>
5
<li>Jane Doe</li>
6
<li>Jane Dane</li>
7
</ul>

Handlebars

1
npm install express-handlebars

Handlebars จะต่างจาก View Engine อื่นเล็กน้อย โดยการใช้ module express-handlebars จากนั้น ก็ใช้ ตัว module กำหนดว่าจะใช้ไฟล์ extension เป็นชื่ออะไร อย่าง Handlebars ก็จะใช้ hbs ฉะนั้นก็เลยตั้งค่าเป็นแบบนี้

1
var handlebars = require('express-handlebars')
2
3
app.engine('hbs', handlebars({ extname: 'hbs' }))
4
5
app.get('/hbs', function (req, res) {
6
res.render('index', {
7
title: 'This is title of Handlebars Template',
8
message: 'Lorem ipsum dolor sit amet, consectetur adipisicing elit',
9
names: ['John Doe', 'Jane Doe', 'Jane Dane']
10
})
11
})

และสร้างไฟล์ index.hbs ขึ้นมาแบบนี้

1
<h1>{{ title }}</h1>
2
<p>{{ message }}</p>
3
<ul>
4
{{#each names }}
5
<li>{{ this }}</li>
6
{{/each}}
7
</ul>

ผลลัพธ์ก็จะได้เช่นเดียวกันกับ View Engine อื่นๆ

1
<h1>This is title of Handlebars Template</h1>
2
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit</p>
3
<ul>
4
<li>John Doe</li>
5
<li>Jane Doe</li>
6
<li>Jane Dane</li>
7
</ul>

สรุป

บทความนี้เป็นแค่ตัวอย่างการ Setup และใช้งาน View Template Engine เบื้องต้นเท่านั้น รายละเอียด และ Features อื่นๆ ที่แต่ละ View Engine มีก็ต้องไปลองอ่านเพิ่มเติมกันเอาเองครับ ส่วนนี้ผมทำไว้เผื่อตัวเองด้วย บางทีก็ลืมๆว่า ต้องกำหนดอะไรบ้าง เหมือนกัน :)

References

Authors
avatar

Chai Phonbopit

เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust

Related Posts