Ash*_*y B 5 javascript routes node.js express
我正在尝试找到在Express中分隔路由的最佳方法.我知道有两种方法,我想知道它们之间有什么区别,哪一种被认为是"最佳实践"(以及为什么).
方法一 - 出口
很多例子似乎都使用这种方法
app.js
var user = require('./routes/users');
app.get('/users', user.list);
Run Code Online (Sandbox Code Playgroud)
路线/ users.js
exports.list = function(req, res){
res.render('users', { title: 'Users', users: users });
};
Run Code Online (Sandbox Code Playgroud)
方法二 -
此方法用于快速指南
app.js
var users = require('./routes/users');
app.use('/users', users);
Run Code Online (Sandbox Code Playgroud)
路线/ users.js
var express = require('express');
var router = express.Router();
router.get('/', function(req, res){
res.render('users', { title: 'Users', users: users });
});
module.exports = router;
Run Code Online (Sandbox Code Playgroud)
正如我上面所说,哪一个是首选方法,为什么?
Ben*_*une 13
方法三 - 使用两者
您应该充分利用Express 4中引入的路由器和控制器的模块化.
app.js
var routes= require('./routes');
app.use('/', routes);
Run Code Online (Sandbox Code Playgroud)
路线/ index.js
var express = require('express');
var users = require('../routes/users');
var router = express.Router();
router.use('/users', users);
module.exports = router;
Run Code Online (Sandbox Code Playgroud)
路线/ users.js
var express = require('express');
var users = require('../controllers/users');
var router = express.Router();
router.get('/', users.list);
module.exports = router;
Run Code Online (Sandbox Code Playgroud)
控制器/ users.js
exports.list = function(req, res){
res.render('users', { title: 'Users', users: users });
};
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1978 次 |
| 最近记录: |