Esta traducción proporcionada por StrongLoop / IBM.
Este documento puede estar desfasado respecto a la documentación en inglés. Para ver las últimas actualizaciones, consulte la documentación en inglés.Utilice el método app.engine(ext, callback) para crear su propio motor de plantilla. ext hace referencia a la extensión de archivo y callback es la función de motor de plantilla, que acepta los siguientes elementos como parámetros: la ubicación del archivo, el objeto options y la función callback.
El siguiente código es un ejemplo de implementación de un motor de plantilla muy simple para la representación de archivos .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
La aplicación ahora podrá representar archivos .ntl. Cree un archivo denominado index.ntl en el directorio views con el siguiente contenido.
#title#
#message#
A continuación, cree la ruta siguiente en la aplicación.
app.get('/', function (req, res) {
  res.render('index', { title: 'Hey', message: 'Hello there!'});
});
Cuando realice una solicitud a la página de inicio, index.ntl se representará como HTML.
