Tento dokument m├┤┼że by┼ą v porovnan├ş s dokument├íciou v angli─Źtine zastaral├Ż. Aktu├ílne inform├ície n├íjdete v dokument├ícii v angli─Źtine.

Ôťľ

V├Żvoj template enginov pre Express

Pre vytvorenie vlastn├ęho template enginu pou┼żite met├│du app.engine(ext, callback). Parameter ext ┼ípecifikuje pr├şponu s├║borov a callback je samotn├í funkcia template enginu, ktor├í pr├şjma nasleduj├║ce prvky ako parametre: cesta k s├║boru, options objekt a callback funkciu.

Nasleduj├║ci k├│d je pr├şkladom implement├ície ve─żmi jednoduch├ęho template enginu pre rendrovanie .ntl s├║borov.


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

Odteraz bude va┼ía aplik├ícia schopn├í rendrova┼ą .ntl s├║bory. Vytvorte s├║bor s n├ízvom index.ntl a views prie─Źinok s nasleduj├║cim obsahom.


#title#
#message#

Potom vo va┼íej aplik├ícii vytvorte tak├Żto route:


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

Ke─Ć vykon├íte request na home page, index.ntl bude vyrendrovan├ę ako HTML.