这是一个例子:
// Configuration
app.configure(function(){
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
(等)
app.get('/memo', function(req, res) {
console.log("index");
Memo.find({}, function(err, data) {
if(err) return next(err);
res.render('index', { memos: data });
});
});
这是另一个:
app.get('/memo/list', function(req, res, next) {
console.log("get memos");
Memo.find({}, function(err, data) {
if(err) return next(err);
res.json(data);
});
});
取自simple memo pad built on node
这些令我困惑的问题是:
next/next();
到底做了什么?如果它不存在会发生什么? next
作为参数而第一部分不是?编辑:
答案 0 :(得分:92)
Express使用具有回调的中间件函数(在操作完成时调用的函数),然后具有该目的(它是触发Express堆栈中下一个中间件的回调)。所有Express中间件(即Connect兼容)都有3个参数:请求,响应,下一个(可选)。
例如静态middlware提供静态文件,csrf中间件在接收POST请求时检查参数,处理路由的路由器中间件(上面粘贴的是其中的一部分)。
如果满足某些条件,每个中间件都可以完成它的任务并调用队列中的next
中间件(例如,静态中间件不会调用下一个中间件,因为它会自行处理服务于文件,以便路由器不会被调用。)
在路由器中,您通常不会调用next
,因为它往往是最后执行的中间件(除非您需要基准测试等)。
如果您想创建一个拒绝访问未登录的所有用户的中间件,则只有在用户登录时才需要调用next()
(以便调用下一个中间件,在这种情况下路由器,用户可以访问他们正在寻找的页面),否则你可能会将它们重定向到登录页面。
next
根本不采用任何参数或将错误作为参数。
编辑:根据您的配置,路由器位于静态中间件之前,因此如果您希望提供文件,则需要声明一条通配路由,当路由不匹配时调用next():
app.get('*', function (req, res, next) {
// no route is matched
// so call next() to pass to the static middleware
next();
});
注意:我不建议你把静态文件服务器放在路由器之后,我建议你先把它放在这里,这样你就可以定义自己的自定义404路由了。