express로 웹서버를 만들더라도 파일을 하나하나 정의하기에는 무리가 있음. express에서 템플릿 엔진을 사용하면 PHP나 JSP처럼 서버에서 HTML을 동적으로 생성할 수 있음.
EJS(Embedded JavaScript) 서버에서 자바스크립트로 HTML을 생성하는 템플릿 엔진
$ npm install -g express-generator
$ express –ejs
구조
app.js
bin
package.json
public
images
javascripts
stylesheets
routes
views
$ npm install
생성후 위 명령어만 입력하면 package.js에 정의된 모듈이 모두 설치됌. bin 디렉터리 아래 www
파일이 생성되는데 node로 실행
$ node bin/www
웹 브라우정에서 http://127.0.0.1:3000 으로 접속하면. 빈화면에 Express Welcome to Express 라고 표시됌.
view/index.eja
1 2 3 4 5 6 7 8 9 10 11 <!DOCTYPE html> <html > <head > <title > <%= title %> </title > <link rel ='stylesheet' href ='/stylesheets/style.css' /> </head > <body > <h1 > <%= title %> </h1 > <p > Welcome to <%= title %> </p > </body > </html >
<% %>
안에 자바스크립트를 사용하면 됌. 변수 출력은 <%= 변수 %>
로 가능.
Welcome to Express 5번 출력하기
1 2 3 4 5 6 7 8 9 10 11 12 13 <!DOCTYPE html> <html > <head > <title > <%= title %> </title > <link rel ='stylesheet' href ='/stylesheets/style.css' /> </head > <body > <h1 > <%= title %> </h1 > <% for (var i = 0; i < 5; i++) { %> <p > Welcome to <%= title %> </p > <% } %> </body > </html >
routes/index.js
1 2 3 4 5 6 7 8 9 var express = require ('express' );var router = express.Router();router.get('/' , function (req, res ) { res.render('index' , { title : 'Express' }); }); module .exports = router;
템플릿 엔진을 이용해서 HTML 생성 가능 아래 사이트 참조
https://code.google.com/p/embeddedjavascript/wiki/ViewHelpers
Jade HTML을 간략화한 템플릿 엔진
$ npm install -g express-generator
$ express
express-generator에 아무 옵션을 주지 않으면 Jade로 어플리케이션을 생성
구조
app.js
bin
package.json
public
images
javascripts
stylesheets
routes
views
EJS와 같이 npm install
입력하면 package.js에 정의된 모듈들이 설치.
$ node bin/www
http://127.0.0.1:3000으로 접속하면 Express Welcome to Express 라고 나오는 것을 확인.
1 2 3 4 5 6 7 doctype html html head title= title link(rel='stylesheet', href='/stylesheets/style.css') body block content
1 2 3 4 5 extends layout block content h1= title p Welcome to #{title}
index.jade
는 extends layout
문법을 이용하여 layout.jade
파일을 상속.
layout.jade, index.jade 파일 모두 block content
가 있음.
layout.jade 파일에서 block을 선언하고, index.jade 파일에서 block을 정의
변수 출력 : ex) h1= title
변수 할당 : ${ }
1 2 3 4 5 6 7 8 9 extends layout block content h1= title p Welcome to #{title} #{ items = ["one", "two", "three"] } each item, i in items li #{item}: #{i}
routes/index.js
1 2 3 4 5 6 7 8 9 var express = require('express'); var router = express.Router(); /* GET home page. */ router.get('/', function(req, res) { res.render('index', { title: 'Express' }); }); module.exports = router;
Handlebars 템플릿 엔진 핸들바스의 사용법을 정리해보자.
설치
$ npm install –save handlebars
템플릿 작성(.hbs) 변수 바인딩, if문, each문의 예제
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 <script id ="entry-template" type ="text/x-handlebars-template" > <div class ="entry" > <h1 > {{title}} </h1 > <div class ="body" > {{body}} </div > </div > <div id ="comments" > {{#each comments}} <h2 > {{title}} ></h2 > <div > {{body}} </div > {{/each }} </div > {{#if author}} <h1 > {{firstName}} {{lastName}} </h1 > {{else }} <h1 > Unknown Author</h1 > {{/if }} </script >
JS code 작성 1 2 3 4 5 6 7 8 9 10 11 var source = $("#entry-template" ).html();var template = Handlebars.compile(source);var context = {title : "My New Post" , body: "This is my first post!" , comments: [ { title : '1' , body : 'xx' }, { title : '2' , body : 'yy' } ], author: { firstName : 'Nam' , lastName : 'Junho' } }; var html = template(context);
partial 1 2 3 4 5 6 7 <div class ="post" > {{> userMessage tagName="h1" }} <h1 > Comments</h1 > {{#each comments}} {{> userMessage tagName="h2" }} {{/each }} </div >
1 2 3 4 5 6 7 8 9 10 11 Handlebars.registerPartial('userMessage' , '<{{tagName}}>By {{author.firstName}} {{author.lastName}}</{{tagName}}>' + '<div class="body">{{body}}</div>' ); var context = { author: {firstName : "Alan" , lastName : "Johnson" }, body: "I Love Handlebars" , comments: [{ author: {firstName : "Yehuda" , lastName : "Katz" }, body: "Me too!" }] };
결과
1 2 3 4 5 6 7 8 <div class ="post" > <h1 > By Alan Johnson</h1 > <div class ="body" > I Love Handlebars</div > <h1 > Comments</h1 > <h2 > By Yehuda Katz</h2 > <div class ="body" > Me Too!</div > </div >
helper 위의 each
나 if
는 내장 helper이며, 그 외에도 다양한 helper를 사용하기 위해서는 swag를 사용하면 된다
$ npm install swag –save
1 2 3 4 5 6 7 8 9 <!-- Browser --> <script src="../path_to/handlebars.js"></script> <script src="../path_to/swag.js"></script> <script>Swag.registerHelpers(Handlebars);</script> // Node Handlebars = require('handlebars'); Swag = require('swag'); Swag.registerHelpers(Handlebars);
string, date, collections 등을 조작하는 다양한 헬퍼를 확인할 수 있다.
https://github.com/elving/swag
Reference http://pyrasis.com/nodejs/nodejs-HOWTO
http://handlebarsjs.com/