路由管理的方式

在同一个文件夹下的情况:

1.基本的有明显get.post的方法。使用express.Router().

var express = require('express');

var router = express.Router();

router.post('/signout', sign.signout); // 登出
router.get('/signin', sign.showLogin); // 进入登录页面
router.post('/signin', sign.login); // 登录校验
router.get('/active_account', sign.activeAccount); //帐号激活

2.基本的,

var app = express();

/*路由规划*/
app.get('/', routes.index);
app.get("/u/:user",routes.user); //用户的主页
app.post('/post',routes.post); //发表信息
app.get('/reg',routes.reg); //用户注册
app.post('/reg',routes.doReg);
app.get('/login',routes.login);//用户登录
app.post('/login',routes.doLogin);
app.get('/logout',routes.logout);//用户退出
http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port'));
});

3. 没有用express.Router(),但是用了app.route的方法。

var app = express();

app.route('/').get(check_login_cmd('html'),         index_cmd);
app.route('/login').get(check_logout_cmd('html'), login_cmd);

//将/creative/下的请求都交给creative,即交给creative目录下的index.js
//来处理,index.js控制二级路由,/user, /ratecard等以此类推
app.use('/creative', creative);
app.use('/user', user);
app.use('/admin', admin);
app.use('/ratecard', ratecard);
app.use('/post', post);
app.use('/spec', spec);
app.use('/ueditor', ueditor);
app.use('/openapi', openapi);
在creative下的index.js文件夹下:

var express = require('express');
var list_cmd = require('./list_cmd');
var find_cmd = require('./find_cmd');

var check_login_cmd = require('../auth/check_login_cmd');

var router = express.Router();

router.get('/list/:appType?/:tId?', check_login_cmd('html'), list_cmd.get);
router.get('/find/:tId/:page/:count', check_login_cmd('json'), find_cmd.get);


在二级路由下面,公开get和post方法。
exports.get = function(req, res) {}
exports.post = function(req, res) {}

=====================================================================
=====================================================================

把路由规划引入另一个js文件的做法。用app.use方法。
1.app.use('/', webRouter);
然后在webRouter的js文件;
var router = express.Router();
router.post('/signout', sign.signout); // 登出
router.get('/signin', sign.showLogin); // 进入登录页面
router.post('/signin', sign.login); // 登录校验
router.get('/active_account', sign.activeAccount); //帐号激活

2.

var app = express();
controller.route(app);
app.route('/').get(check_login_cmd('html'), index_cmd);
app.route('/login').get(check_logout_cmd('html'), login_cmd);

//将/creative/下的请求都交给creative,即交给creative目录下的index.js
//来处理,index.js控制二级路由,/user, /ratecard等以此类推
app.use('/creative', creative);
app.use('/user', user);
app.use('/admin', admin);

==========================

模块的定义方式:

方法1.

function Person(){
  var name;
  this.setName = function(theName){
    name = theName;
  };
  this.sayHello = function(){
    console.log('Hello',name);
  };
}
// exports.Person = Person;
module.exports = Person;
方法2. 比如 site.js模块
exports.index = function (req, res, next) {}
exports.sitemap = function (req, res, next) {}
调用的方式:router.get('/', site.index);
方法3:
exports.get = function(req, res) {}
exports.post = function(req, res){}
这里调用的时候,不需要写方法名。
==================================




原文地址:https://www.cnblogs.com/coding4/p/5560187.html