为 Express 开发模板引擎

为 Express 开发模板引擎

使用 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(err)

// this is an extremely simple template engine

const 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

你的应用现在将能够渲染 .ntl 文件。在 views 目录中创建一个名为 index.ntl 的文件,内容如下。

#title#

#message#

然后,在你的应用中创建以下路由。

app.get('/', (req, res) => {

res.render('index', { title: 'Hey', message: 'Hello there!' })

})

当你向主页发出请求时,index.ntl 将被渲染为 HTML。

编辑此页面

相关文章

手机GPS打不开解决方法大全

粤Z是哪里的车牌号码,粤Z是哪个城市的车牌号

中国各朝代服饰配色大赏:窃蓝、绛紫、朱红……高级透了!