1

好吧 - 我读得越多,我就越困惑。所以这里的来源:

var express = require('express')
  , http = require('http')
  , server = express()
  ;

var home = require('./routes/home.js')
  , about = require('./routes/about.js')
  , contact = require('./routes/contact.js');

  server.configure(function () {
  server.set('port', process.env.PORT || 3000);
  server.set('view engine', 'hjs');
  server.set('views', __dirname + '/views');
  server.use(express.logger());
  server.use(server.router);
  server.use(express.favicon());
  server.use(require('stylus').middleware(__dirname + '/public'));
  server.use(express.static(__dirname + '/public'));
  server.use(express.bodyParser());
  server.use(express.cookieParser('your secret here'));
  server.use(express.methodOverride());
  server.use(express.session());
});

server.get('*', function (req, res) {
  switch (req.path) {

    case '/':
      res.render('home', { title:'Home Page' });
      break;

    case '/about/':
      res.render('home', { title:'About Page' });
      break;

    case '/contact/':
      res.render('contact', { title:'Contact Page' });
      break;

    default:
      res.render('home', { title:'404 - Page not found'});
  }
});

好吧,它正在工作,但我仍然没有将那个 req/res 组合放入我的头骨。我很确定我不需要'*'那里作为参数。但是我不知道如何建立更好的解决方案。任何简单的愚蠢愚蠢的例子,所以我可以想象魔法是如何运作的。

为了简化我的谜语,我想知道(并理解)为什么会这样:

server.get('*', function (req, res) {

但这不是

server.get(function (req, res) {

第一个参数总是被处理为究竟是什么?

4

1 回答 1

1

我相信第一个参数是路线。您可以将代码分解为以下可能更有意义的代码,并遵循约定:

server.get('/', function (req, res) {
    res.render('home', { title:'Home Page' });
})

server.get('/contact/', function (req, res) {
    res.render('contact', { title:'Contact Page' });
});

server.get('*', function (req, res) {
    res.render('Page Not Found', 404);
});

等等……

'*'您正在使用的只是接受所有路线。类似于通配符!

于 2012-06-27T19:11:08.160 回答