expressjs作为nodejs的MVC框架,其路由规则与大部分其他MVC框架类似,略有不同,研究后做个小记。

expressjs路由在app.js中配置,app.js源码如下(不同的版本会有所不同,以下为express 4.13.1):

 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 routes = require('./routes/index');
 9 var users = require('./routes/users');
112 var app = express();
13
14 // view engine setup
15 app.set('views', path.join(__dirname, 'views'));
16 app.set('view engine', 'jade');
17
18 // uncomment after placing your favicon in /public
19 //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
20 app.use(logger('dev'));
21 app.use(bodyParser.json());
22 app.use(bodyParser.urlencoded({ extended: false }));
23 app.use(cookieParser());
24 app.use(express.static(path.join(__dirname, 'public')));
25
26 app.use('/', routes);
27 app.use('/users', users);30 // catch 404 and forward to error handler
31 app.use(function(req, res, next) {
32   var err = new Error('Not Found');
33   err.status = 404;
34   next(err);
35 });
36
37 // error handlers
38
39 // development error handler
40 // will print stacktrace
41 if (app.get('env') === 'development') {
42   app.use(function(err, req, res, next) {
43     res.status(err.status || 500);
44     res.render('error', {
45       message: err.message,
46       error: err
47     });
48   });
49 }
50
51 // production error handler
52 // no stacktraces leaked to user
53 app.use(function(err, req, res, next) {
54   res.status(err.status || 500);
55   res.render('error', {
56     message: err.message,
57     error: {}
58   });
59 });
60
61
62 module.exports = app;

先对app.js进行说明,app.js文件中包含以下功能块:

1.模块的加载

 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 routes = require('./routes/index');//express默认生成的index和users文件9 var users = require('./routes/users');

2.设置视图view和模板引擎(express默认jade)

15 app.set('views', path.join(__dirname, 'views'));
16 app.set('view engine', 'jade');//express默认为jade,如果想用ejs模板,直接修改,前提是要安装。

3.中间件配置app.use

8 // uncomment after placing your favicon in /public
19 //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
20 app.use(logger('dev'));
21 app.use(bodyParser.json());
22 app.use(bodyParser.urlencoded({ extended: false }));
23 app.use(cookieParser());
24 app.use(express.static(path.join(__dirname, 'public')));

4.配置路由

26 app.use('/', routes);//将routes模块提交给app
27 app.use('/users', users);//将users模块提交给app

第一个参数为路由路径,即url路径;第二个参数为模块名称,即在加载模块的时候赋予的变量名。

也就是将该路径与模块建立映射关系,如/users路径将于users模块建立关系。当输入url请求过来后,express会解析到相应的模块去处理请求,如上users.js模块。

在users.js中可以直接返回数据或者加载视图。

如果要加载视图,那么该路径一定要与view中的目录结构相匹配,否则无法加载。例如路由是/new/newslist,那么视图view下要有匹配的目录/views/new/newslist。

routes的目录与views目录结构相对应,才能加载成功。express根据路由/new/newslist去找routes下的newslist.js模块(文件),newslist.js文件中通过render去加载视图,代码如下:

var express = require('express');
var router = express.Router();//从express中取出router/* GET users listing. */
router.get('/', function(req, res, next) {res.render('newslist', { title: 'Express' });
});module.exports = router;

express会根据之前配置的路由去views下找相应的模板文件viewslist.jade进行操作。

5.处理404和500错误

 // catch 404 and forward to error handler
31 app.use(function(req, res, next) {
32   var err = new Error('Not Found');
33   err.status = 404;
34   next(err);
35 });
36
37 // error handlers
38
39 // development error handler
40 // will print stacktrace
41 if (app.get('env') === 'development') {
42   app.use(function(err, req, res, next) {
43     res.status(err.status || 500);
44     res.render('error', {
45       message: err.message,
46       error: err
47     });
48   });
49 }
50
51 // production error handler
52 // no stacktraces leaked to user
53 app.use(function(err, req, res, next) {
54   res.status(err.status || 500);
55   res.render('error', {
56     message: err.message,
57     error: {}
58   });
59 });

转载于:https://www.cnblogs.com/goodpan/p/5001341.html

expressjs路由匹配规则相关推荐

  1. 互联网技术-alibaba-gateway网关中routers路由匹配规则

    gateway的主要功能之一是转发请求,转发规则的定义主要包含三个部分 组成 描述 路由 Route 路由是网关的基本单元, 由ID.URI.一组Predicate.一组Filter组成,根据Pred ...

  2. django中路由匹配规则

    1.定义 指url与后端视图之间的一一映射关系 2.添加路由以及匹配规则 1)需要在全局路由文件中(url.py),urlpatterns列表中添加路由条目 2)urlpatterns是固定的,是列表 ...

  3. Nginx篇之路由匹配规则以及配置url转发

    一.前言 一般我们经常在访问网站时,通常会遇到输入某个页面的网址时,出现路由的转发,重定向等.可能访问的是一个网址,出来的时候就显示的是另外的地址. 这种情况下,通常属于nginx的页面跳转. 二.N ...

  4. linux 路由匹配原则,Nginx localhost路由匹配规则

    URI 即统一标识资源符,通用的 URI 语法格式如下: scheme:[//[user[:password]@]host[:port]][/path][?query][#fragment] 格式说明 ...

  5. React 路由匹配模式

    React 路由匹配模式 react中的路由按照路径的正则进行匹配,很容易出现同时匹配多个路由组件的情况,路由规则提供了一个唯一匹配模式组件:Switch 问题:添加Switch没有任何反应,且各个页 ...

  6. 【TP3.2】路由匹配和规则

    TP3.2框架的路由匹配和规则处理: 包括:静态路由,动态路由,多参数路由.正则路由 <?php return array(//'配置项'=>'配置值'/* * 路由开启和匹配.首先开启路 ...

  7. Django中url匹配规则的补充

    Django中url匹配规则是在urls.py文件中配置的. 1.关于正则匹配优先级 在url匹配列表中,如果第一条和第二条同时满足匹配规则,则优先匹配第一条. 在url匹配列表中,如果第一条为正则模 ...

  8. nginx匹配规则_Nginx系列之server_name定义与匹配规则

    Nginx系列之server_name定义与匹配规则 server_name用来指定请求中的Host头部,在上一节的基于域名的虚拟机中,nginx匹配的规则就是根据server_name的不同,结合请 ...

  9. vue路由匹配实现包容性_包容性设计:面向老年用户的数字平等

    vue路由匹配实现包容性 In Covid world, a lot of older users are getting online for the first time or using tec ...

最新文章

  1. 简单介绍一下umask 命令使用方法
  2. 原创译文 | 通过设计让学习变轻松
  3. cmd mysql 报错_客户端cmd打开mysql,执行插入中文报错或插入中文乱码解决方案
  4. 【编程题目】复杂链表的复制☆
  5. [css] 使用overflow: scroll时不能平滑滚动怎样解决?
  6. 使用乱序标签来控制HTML的输出效果
  7. 中信银行MySQL面试_【深圳中信银行信用卡中心面试】面试题_面试经验_面试流程-看准网...
  8. 飞鸽传书2008一种重要心态
  9. .NET中的异步编程 - 动机和单元测试
  10. python的flask微服务-flask微服务框架的初步接触
  11. cad布局怎么用_【CAD】CAD布局怎么用?
  12. 2008 r2 server sql 中文版补丁_sql2008 sp3补丁下载-sql server 2008补丁包sp3中文版补丁【32/64位】-东坡下载...
  13. 计算机美术设计基础教案,电脑美术美术教案
  14. 查看/设置windows密钥
  15. 『python思考』关于列表的浅复制和深复制的理解
  16. SpringBoot整合dubbo详解(阿里官方dubbo-spring-boot-starter)
  17. 关于jeecg 项目的莫名其妙的问题
  18. 怀念上世纪90年代的中国摇滚乐
  19. Laravel php 框架的使用写出第一个hello world,Laravel 入门配置
  20. 记几次 [线上环境] Dubbo 线程池占满原因分析(第三次:GC STW)

热门文章

  1. 马斯克躺枪得州最严堕胎法案,因拒绝表态遭炮轰!“不站女权就抵制特斯拉”...
  2. 对话图灵奖得主John Hennessy,他说对美国留学签证变化很忧心
  3. MIT录取不再看SAT科目成绩:曾是华裔传统优势,数学等学科测验更是中国留学生强项...
  4. iPhone销售额下滑12%,但AirPods和手表救了苹果
  5. 参加动物AI奥运会,让你的智能体比狗狗还聪明,挣取3.2万美元奖金
  6. jQuery操作input
  7. python—函数实例一
  8. ZigZag 与 反ZigZag编码
  9. Console命令详解,让调试js代码变得更简单
  10. kqueue epoll 边界触发模式的网络编程模型