Template-Engines für Express entwickeln

Verwenden Sie die Methode app.engine(ext, callback), um Ihre eigene Template-Engine zu erstellen. ext bezieht sich auf die Dateierweiterung, callback ist die Template-Engine-Funktion, die die folgenden Elemente als Parameter akzeptiert: die Position der Datei, das Optionsobjekt und die Callback-Funktion.

Der folgende Code ist ein Beispiel für die Implementierung einer sehr einfachen Template-Engine für die Ausgabe von .ntl-Dateien.

const fs = require('fs'); // this engine requires the fs module
app.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 directory
app.set('view engine', 'ntl'); // register the template engine

Ihre Anwendung ist jetzt in der Lage, .ntl-Dateien auszugeben. Erstellen Sie im Verzeichnis views eine Datei namens index.ntl mit dem folgenden Inhalt.

#title#
#message#

Erstellen Sie dann in Ihrer Anwendung die folgende Route.

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

Wenn Sie eine Anforderung zur Homepage einleiten, wird index.ntl im HTML-Format ausgegeben.