如何在Express.js中定义单个页面

时间:2014-07-19 21:38:23

标签: javascript html5 node.js express pug

我刚刚开始使用 express.js ,并且我无法理解如何定义可以在内部链接的离散“页面”(在传统意义上)。

我正在使用Jade作为模板引擎,我看到它如何将各种组件拉到一起并在app.js中引用它们(这是最初由npm调用的),因此,实际上是我的“索引” 。很高兴看到一个关于人们做什么然后构建pageA,pageB,pageC的教程,以便它们可以通过<a href="pageA.html">(或等效的Jade)链接到。

我认为这是可能的,对吧?

1 个答案:

答案 0 :(得分:1)

Express.js本身不提供URL生成,只提供内置路由器。

您需要使用其他程序包来执行URL生成,或自行构建。也许你在这个问题的答案中找到了合适的东西:URL generation for routes in express

如果您不关心路线生成并希望“硬编码”网址,则需要为每个静态网页添加路径,如下所示:

// routes.js
app.get("/pageA.html", function(req, res, next) { res.render("static/page_a", { templateLocals: "here" }) };
app.get("/pageB.html", function(req, res, next) { res.render("static/page_b") };

或者,如果您有许多这样的页面,可以使用控制器

// static_page_controller.js
module.exports = function(pageTemplate) {
  return function(req, res, next) {
    return res.render("static/" + pageTemplate);
  }
}

并像这样使用它:

// routes.js
var staticController = require("./static_page_controller");

app.get("/pageA.html", staticController("page_a"));