StrongLoop의 Express 및 Node.js 교육

StrongLoop / IBM에 의해 제공이 번역.

이 문서는 영문판 문서에 비해 더 오래된 버전일 수도 있습니다. 최신 업데이트를 확인하려면 영문판 문서를 참조하십시오.

Express용 템플리트 엔진 개발

app.engine(ext, callback) 메소드를 사용하면 자신만의 템플리트 엔진을 작성할 수 있습니다. ext는 파일 확장자를 나타내며, callback은 파일의 위치, 옵션 오브젝트 및 콜백 함수 등의 항목을 매개변수로 수락하는 템플리트 엔진 함수입니다.

다음의 코드는 .ntl 파일을 렌더링하기 위한 매우 간단한 템플리트 엔진을 구현하는 예입니다.


var fs = require('fs'); // this engine requires the fs module
app.engine('ntl', function (filePath, options, callback) { // define the template engine
  fs.readFile(filePath, function (err, content) {
    if (err) return callback(new Error(err));
    // this is an extremely simple template engine
    var rendered = content.toString().replace('#title#', ''+ options.title +'')
    .replace('#message#', '

'+ options.message +'

'); return callback(null, rendered); }); }); app.set('views', './views'); // specify the views directory app.set('view engine', 'ntl'); // register the template engine

앱은 이제 .ntl 파일을 렌더링할 수 있습니다. 다음의 내용이 입력된 index.ntl이라는 이름의 파일을 views 디렉토리에 작성하십시오.


#title#
#message#

이후 앱에 다음과 같은 라우트를 작성하십시오.


app.get('/', function (req, res) {
  res.render('index', { title: 'Hey', message: 'Hello there!'});
});

홈 페이지에 대한 요청을 실행할 때 index.ntl은 HTML로 렌더링됩니다.