express框架在node官方推荐的一个框架,关于如何入门的文章,已经很多了,我就不在累赘了,本文的核心是如何修改文件使得更接近一个MVC的框架

express原生是通过require的方式实现了模块的加载,而且是在程序启动时一次性全部加载(因此我的按需加载的方案搁浅了),如果在配置路由的时候都加载一次,然后全部写在app.js文件中,我的天呐,对于一个大型项目来说极难维护,因此必须将其分割。下面我们就来干这么一件事。

上图是我的文件目录:

  1.   controller  文件夹是控制器
  2. model 文件夹是数据模型
  3. config.js 是配置文件
  4. app.js  默认主文件
  5. route.js 路由配置文件(我删除了原来的route文件,将其中的文件移到了controller中)

先来看看我的app.js吧

  1. var express = require('express');
  2. var path = require('path');
  3. var favicon = require('serve-favicon');
  4. var logger = require('morgan');
  5. var cookieParser = require('cookie-parser');
  6. var bodyParser = require('body-parser');
  7.  
  8. var route = require("./route");
  9.  
  10. var app = express();
  11.  
  12. // view engine setup
  13. app.set('views', path.join(__dirname, 'views'));
  14. app.set('view engine', 'ejs');
  15.  
  16. // uncomment after placing your favicon in /public
  17. //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
  18. app.use(logger('dev'));
  19. app.use(bodyParser.json());
  20. app.use(bodyParser.urlencoded({ extended: false }));
  21. app.use(cookieParser());
  22. app.use(express.static(path.join(__dirname, 'public')));
  23.  
  24. route(app);
  25.  
  26. // catch 404 and forward to error handler
  27. app.use(function(req, res, next) {
  28. var err = new Error('Not Found');
  29. err.status = 404;
  30. next(err);
  31. });
  32.  
  33. // error handlers
  34.  
  35. // development error handler
  36. // will print stacktrace
  37. if (app.get('env') === 'development') {
  38. app.use(function(err, req, res, next) {
  39. res.status(err.status || 500);
  40. res.render('error', {
  41. message: err.message,
  42. error: err
  43. });
  44. });
  45. }
  46.  
  47. // production error handler
  48. // no stacktraces leaked to user
  49. app.use(function(err, req, res, next) {
  50. res.status(err.status || 500);
  51. res.render('error', {
  52. message: err.message,
  53. error: {}
  54. });
  55. });
  56.  
  57. module.exports = app;

上面代码中第8行和24行是我修改的地方,不再使用默认的路由方式。

再来看看route.js文件

  1. "use strict";
  2. const path = require("path");
  3. const url = require("url");
  4. const config = require("./config");
  5.  
  6. /**
  7. * reqUrl is the current request url
  8. * this function will help load the controller acconding to the url
  9. * **/
  10. function getCtrl(reqUrl){
  11. var ctrlName = url.parse(reqUrl).pathname;
  12. return require(path.join(config.root,config.ctrlPath,ctrlName));
  13. }
  14.  
  15. module.exports = function(app){
  16. //pakage the app.use
  17. var depatch = function(url){
  18. app.use(url,getCtrl(url));
  19. };
  20.  
  21. depatch("/");
  22. depatch("/users");
  23. depatch("/admin/");
  24.  
  25. };

  通过对express默认的app.use()的简单封装,即可根据路由自动完成controller的加载。当然,简单需要付出代价,那就是必须保证controller的位置和url必须对应起来。这样做也比一行行require容易多了,不是吗?

  再来简单瞧一眼config.js是怎么写的

  1. "use strict";
  2.  
  3. var config = {
  4. root: __dirname,
  5. ctrlPath: "controller"
  6. };
  7.  
  8. module.exports = config;

  当然根据项目可以继续扩展config了。

express框架路由配置及congtroller自动加载的更多相关文章

  1. SSH框架项目配置和启动的加载顺序及请求的执行顺序

    1:======配置和启动====== (1)配置web.xml 配置<context-param>,其中内容为Spring的配置文件applicationContext.xml.注意&l ...

  2. Yaf框架下类的自动加载

    前面两篇博客分别讲述了PHP自带的类加载和composer中类的自动加载,其实Yaf框架也实现了基于PSR0和PSR4的类的自动加载.根据我对Yaf下类的自动加载方式的理解写下这篇博客.由于接触Yaf ...

  3. CI框架源码阅读笔记9 CI的自动加载机制autoload

    本篇并不是对某一组件的详细源码分析,而只是简单的跟踪了下CI的autoload的基本流程.因此,可以看做是Loader组件的分析前篇. CI框架中,允许你配置autoload数组,这样,在你的应用程序 ...

  4. thinkphp系列:类的自动加载是如何设计的

    在使用框架开发时,可以发现框架有很多核心类,却很少看到显示的引入某个文件的代码,这是因为框架都采用了类的自动加载机制,即使用到类时,框架会自动找到该类所在文件的位置并引入该文件.为了更容易看出代码思路 ...

  5. Tomcat7 自动加载类及检测文件变动原理

    在一般的web应用开发里通常会使用开发工具(如Eclipse.IntelJ)集成tomcat,这样可以将web工程项目直接发布到tomcat中,然后一键启动.经常遇到的一种情况是直接修改一个类的源文件 ...

  6. composer 自动加载源码解析

    一直在用 composer,最近想看一下具体的原理是什么,就仔细阅读了一下源码,一下是个人理解.在看该文章前最好了解一下 PSR-4 自动加载规范 引入类自动加载文件 # 加载类自动加载文件 requ ...

  7. php之自动加载(懒加载)

    有A类和B类,如果在A类实例化B类,最简单直接的方法就是在B中使用include require_once A的文件,但是这种方法显然是不友好的,在框架中叶不是这么做的,在框架中使用的是自动加载的机制 ...

  8. Tomcat 7 自动加载类及检测文件变动原理

    在一般的 web 应用开发里通常会使用开发工具(如 Eclipse.IntelJ )集成 tomcat ,这样可以将 web 工程项目直接发布到 tomcat 中,然后一键启动.经常遇到的一种情况是直 ...

  9. php怎么自动加载

    在 PHP 代码的顶部你是不是经常看到这样的代码. require 'lionis.php'; require 'is.php'; require 'cool.php'; 如果只是引入几个 PHP 脚 ...

随机推荐

  1. MySQL(Percona Server) 5.6 主从复制

    MySQL(Percona Server) 5.6.15 主库:192.168.2.21 从库:192.168.2.22 例如我们同步的数据库为:test. 如果需要同步多个数据库下面会有说明. My ...

  2. 7.echo(),print(),print_r()的区别

    echo是PHP语句, print和print_r是函数,语句没有返回值,函数可以有返回值(即便没有用) print()    只能打印出简单类型变量的值(如int,string) print_r() ...

  3. Request 、Response 与Server的使用

    纯属记录总结,以下图片都是来自 ASP.NET笔记之 Request .Response 与Server的使用 Request Response Server 关于Server.MapPath 方法看 ...

  4. mysql优化杂记

    一.mysqladmin的使用#mysqladmin extended-status -u root -i 2 -c 2 -p | grep connect查看mysql的状态中带有connect字符 ...

  5. Spark会把数据都载入到内存么

    转载自:https://www.iteblog.com/archives/1648 前言: 很多初学者其实对于Spark的编程模式还是RDD这个概念理解不到位,就会产生一些误解.比如,很多时候我们常常 ...

  6. 如何给main传参数

    main 函数的参数有连个argc argcv[]  argc 是参数个数 argcv是参数的数组指针,且argcv的第一个参数是默认程序路径加程序名 给main传参数,需要在命令行启动程序时设置 如 ...

  7. scala中的Actor

    1.介绍 2.简单示例 3.第二个程序 4.通信程序 package day01 import scala.actors.Actor case class Message(content: Strin ...

  8. 关于swap函数传值的问题

    #include <stdio.h> void swap(int * p3,int * p4); int main() {  int a = 9;  int b = 8;  int * p ...

  9. jvm 配置

    # 内存参数MEMORY_OPTS="-Xms2048m -Xmx2048m -Xmn1024m -XX:MaxDirectMemorySize=2048m -XX:PermSize=256 ...

  10. IE环境下判断IE版本的语句...[if lte IE 6]……[endif][if lte IE 7]……[endif]

    <!--[if IE 6]> <![endif]--> 只有IE6版本可见 <!--[if lte IE 6]> <![endif]--> IE6及其以 ...