zoukankan      html  css  js  c++  java
  • 路由管理的方式

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

    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){}
    这里调用的时候,不需要写方法名。
    ==================================




  • 相关阅读:
    nginx添加新模块
    nginx rewrite规则last与break的区别
    tomcat调优的几个方面
    Servlet 中文乱码问题及解决方案剖析
    Nginx 启动脚本/重启脚本
    Nginx的启动、停止、平滑重启
    轻量级HTTP服务器Nginx(配置与调试Nginx)
    Nginx配置文件详细说明
    提高Java代码质量的Eclipse插件之Checkstyle的使用详解
    你会用shuffle打乱列表吗?
  • 原文地址:https://www.cnblogs.com/coding4/p/5560187.html
Copyright © 2011-2022 走看看