1.为Express开发模板引擎 | 1. Developing template engines for Express (Advanced topics) – Express 中文开发手册

作者: Arvin Chen 分类: JavaScript 来源: Break易站(www.breakyizhan.com)

1.为Express开发模板引擎 | 1. Developing template engines for Express (Advanced topics) - Express 中文开发手册

使用app.engine(ext, callback)方法创建您自己的模板引擎。ext指的是文件扩展名,并且callback是模板引擎函数,它接受以下项作为参数:文件的位置,选项对象和回调函数。

以下代码是实现用于呈现.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(err)
    // this is an extremely simple template engine
    var 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文件。使用以下内容在views目录中创建一个名为index.ntl的文件。

#title#
#message#

然后,在您的应用程序中创建以下路线。

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

当您向主页发出请求时,index.ntl将会呈现为HTML。

  •   本文标题:1.为Express开发模板引擎 | 1. Developing template engines for Express (Advanced topics) – Express 中文开发手册 - Break易站
    转载请保留页面地址:https://www.breakyizhan.com/javascript/38307.html
      微信返利机器人
      免费:淘宝,京东,拼多多优惠券
      腾讯,爱奇艺,优酷的VIP视频免费解析,免费看
      即刻扫描二维码,添加微信机器人!