Этот перевод обеспечивается StrongLoop / IBM.
Этот документ может быть устаревшим по отношению к документации на английском языке. Последние обновления содержатся в документации на английском языке.Для создания собственного шаблонизатора воспользуйтесь методом app.engine(ext, callback)
. ext
соответствует расширению имени файла, а callback
является функцией шаблонизатора, принимающей в качестве параметров следующие элементы: расположение файла, объект опций и функцию обратного вызова.
Приведенный ниже код служит примером реализации самого простого шаблонизатора для вывода файлов .ntl
.
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(new Error(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
Теперь ваше приложение сможет отображать файлы .ntl
. Создайте файл с именем index.ntl
в каталоге views
со следующим содержимым.
#title#
#message#
Затем создайте следующий маршрут в своем приложении.
app.get('/', (req, res) => {
res.render('index', { title: 'Hey', message: 'Hello there!' })
})
При выполнении запроса к домашней странице файл index.ntl
будет отображаться как HTML.