Desarrollar motores de plantillas para Express
Usa el método app.engine(ext, callback) para crear tu propio motor de plantillas. ext se refiere a la extensión del archivo, y callback es la función del motor de plantilla, que acepta los siguientes elementos como parámetros: la ubicación del archivo, el objeto de opciones y la función de devolución de llamada.
El siguiente código es un ejemplo de implementación de un motor de plantillas muy simple para renderizar archivos .ntl.
const fs = require('fs'); // this engine requires the fs moduleapp.engine('ntl', (filePath, options, callback) => { // define the template engine fs.readFile(filePath, (err, content) => { if (err) return callback(err); // this is an extremely simple template engine const rendered = content .toString() .replace('#title#', `<title>${options.title}</title>`) .replace('#message#', `<h1>${options.message}</h1>`); return callback(null, rendered); });});app.set('views', './views'); // specify the views directoryapp.set('view engine', 'ntl'); // register the template engineTu aplicación ahora será capaz de procesar archivos .ntl. Crea un archivo llamado index.ntl en el directorio views con el siguiente contenido.
#title##message#Luego, crea la siguiente ruta en tu aplicación.
app.get('/', (req, res) => { res.render('index', { title: 'Hey', message: 'Hello there!' });});Cuando hagas una solicitud a la página de inicio, index.ntl será renderizado como HTML.