`

Express 路由导航

阅读更多

路由:

路由定义了如何响应客户端请求以及响应结束点。

 

路由是URI的组成部分,包含http请求方法,和一个或多个处理方法。路由的结构为“app.METHOD(path,[callback...],callback)"。”app“是一个express实例,”METHOD“为http请求方法,”path“是服务路径,”callback“路径匹配时执行的方法。

 

下面是一个非常基础的路由示例:

 

var express = require('express')
var app = express()

// respond with "hello world" when a GET request is made to the homepage
app.get('/', function(req, res) {
  res.send('hello world')
})

 

 

路由方法:

路由方法衍生于HTTP方法,是express实例的属性。

下面是关于路由的一个例子,定义了应用根路径的GET和POST方法:

 

// GET method route
app.get('/', function (req, res) {
  res.send('GET request to the homepage')
})

// POST method route
app.post('/', function (req, res) {
  res.send('POST request to the homepage')
})

 Express提供了一下路由方法,相当于HTTP方法的:get,post,put,head,delete,options,trace,copy,lock,mkcol,move,purge,propfind,proppatch,unlock,report,mkactivity,checkout,merge,m-search,notify,subscribe,unsubscribe,patch,search,connect。

 

 

使用方括号([ ])记法,可以通过javascript变量名调用路由方法,例如: app.['m-search']('/',function...)

 

这里有个一个特殊的路由方法”app.all()",不衍生于任何HTTP方法。它被用于为所有请求方法的路径加载中间件。

例如,下面的例子中,使用GET,POST,PUT,DELETE或“http module”模块提供的其他HTTP请求方法访问“/secret”路径时,将运行处理方法。

 

app.all('/secret', function (req, res, next) {
  console.log('Accessing the secret section ...')
  next() // pass control to the next handler
})

  

 

路由路径:

路由路径,结合路由方法,定义了请求的端点以及哪一类请求可以访问。路径可以是字符串,字符串模式或者正则表达式。

 

备注:Express使用“path-to-regexp”来匹配路径,关于路径的详细信息可以参考它的文档。“Express Route Tester”是测试Express路由的处理工具。

 

注意:查询字符串不是路由路径的一部分。

 

下面是字符串路由路径的例子:

 

// 匹配根“/”路径
app.get('/', function (req, res) {
  res.send('root')
})

// 匹配“/about”路径
app.get('/about', function (req, res) {
  res.send('about')
})

// 匹配"/random.text"路径
app.get('/random.text', function (req, res) {
  res.send('random.text')
})

 下面是字符串模式路由路径的例子:

 

 

// will match acd and abcd
app.get('/ab?cd', function(req, res) {
  res.send('ab?cd')
})

// will match abcd, abbcd, abbbcd, and so on
app.get('/ab+cd', function(req, res) {
  res.send('ab+cd')
})

// will match abcd, abxcd, abRABDOMcd, ab123cd, and so on
app.get('/ab*cd', function(req, res) {
  res.send('ab*cd')
})

// will match /abe and /abcde
app.get('/ab(cd)?e', function(req, res) {
 res.send('ab(cd)?e')
})

 备注:字符?,+,*和()是Express中正则表达式的子集.连字符(-)和点号(.)基于字符串路径逐字解释.

 

 

下面是正则表达式路由路径的例子:

 

// will match anything with an a in the route name:
app.get(/a/, function(req, res) {
  res.send('/a/')
})

// will match butterfly, dragonfly; but not butterflyman, dragonfly man, and so on
app.get(/.*fly$/, function(req, res) {
  res.send('/.*fly$/')
})

 

 

路由处理方法:

你可以针对一个请求提供多个回调函数,它们的行为就像中间件.这里有一个特殊情况: 当回调函数调用"next('route')"时,就会忽略剩余的回调函数.你可以利用这个机制给路径添加先决条件;满足条件则执行后续的路径,不满足条件则继续执行当前路径.

 

路由处理可以是单个的函数,也可以是函数数组,或者两者结合使用.下面是相关的例子:

使用单个函数处理:

 

app.get('/example/a', function (req, res) {
  res.send('Hello from A!')
})

使用多个函数处理(确保指定了'next'对象):

 

 

app.get('/example/b', function (req, res, next) {
  console.log('response will be sent by the next function ...')
  next()
}, function (req, res) {
  res.send('Hello from B!')
})

  使用函数数组处理:

 

 

var cb0 = function (req, res, next) {
  console.log('CB0')
  next()
}

var cb1 = function (req, res, next) {
  console.log('CB1')
  next()
}

var cb2 = function (req, res) {
  res.send('Hello from C!')
}

app.get('/example/c', [cb0, cb1, cb2])

 使用函数数组和独立的函数组合处理:

 

 

var cb0 = function (req, res, next) {
  console.log('CB0')
  next()
}

var cb1 = function (req, res, next) {
  console.log('CB1')
  next()
}

app.get('/example/d', [cb0, cb1], function (req, res, next) {
  console.log('response will be sent by the next function ...')
  next()
}, function (req, res) {
  res.send('Hello from D!')
})

 

 

响应方法:

下表中响应对象(res)的方法,用于响应客户端的请求并结束请求响应周期.如果在路由处理函数中没有调用任何响应方法,那么客户端的请求将被挂起.

res.download() 提示文件被下载
res.end() 结束响应过程
res.json() 发送JSON响应
res.jsonp() 发送支持JSONP的JSON响应
res.redirect() 重定向请求
res.render() 渲染视图模板
res.send() 发送各种类型的响应
res.sendFile() 将指定文件作为字节流响应
res.sendStatus()

设置响应状态码,并发送其字符串表示为响应体。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

app.route()

可以用app.route()创建链式路由处理。由于路径在一个位置指定,它有助于创建模块化路线,减少冗余和错别字。有关路由的详细信息,请参阅路由文档

 

下面是使用app.route()定义的链式路由处理的例子:

app.route('/book')
  .get(function(req, res) {
    res.send('Get a random book');
  })
  .post(function(req, res) {
    res.send('Add a book');
  })
  .put(function(req, res) {
    res.send('Update the book');
  })

 

express.Router

express.Router类可用于创建模块化可安装的路由处理程序。一个Router实例是一个完整的中间件和路由系统;因为这个原因,它通常被称为“小应用程序”。

 

下面的示例演示创建一个路由模块,并加载中间件,定义路径,并将它安装在主应用的一个路径上。

 

在应用文件夹中创建一个birds.js的文件,并添加如下内容:

var express = require('express');
var router = express.Router();

// middleware specific to this router
router.use(function timeLog(req, res, next) {
  console.log('Time: ', Date.now());
  next();
})
// define the home page route
router.get('/', function(req, res) {
  res.send('Birds home page');
})
// define the about route
router.get('/about', function(req, res) {
  res.send('About birds');
})

module.exports = router;

 然后在应用中加载这个路由模块:

var birds = require('./birds');
...
app.use('/birds', birds);

 现在该应用将能够处理"/birds"和"/birds/about"路径上的请求,以及调用特别为路由配置的中间件timeLog。

 

以上内容翻译自Express官网文档,原文参考Express Routing

 

 

 

 

 

 

 

0
1
分享到:
评论

相关推荐

    node.js Express框架路由模块化

    首先,路由在Express中扮演着导航者的角色,它定义了服务器如何响应特定的HTTP请求方法(如GET、POST等)和URL路径。模块化路由则是将这些路由逻辑分解到单独的模块中,以提高代码的可读性和可维护性。这种方式有助...

    node+express+bootstrap博客案例

    2. **Express应用结构**:路由配置、中间件机制、视图系统(如ejs模板引擎)的应用。 3. **HTTP协议**:理解GET和POST请求的区别,以及如何通过Express处理这些请求。 4. **数据库操作**:可能包括连接数据库、CRUD...

    路由所有代码,路由所有代码

    例如,Express.js是Node.js中常用的后端路由库。 - 在服务器端,路由可以进行身份验证、权限检查,甚至返回静态资源或执行数据库查询。 4. **导航栏**: - 导航栏是Web应用的常见元素,显示可用的页面链接,帮助...

    Express模拟后端数据

    Vue Router是官方的路由管理器,用于处理页面导航和状态,与Vue2.x配合使用,实现单页应用(SPA)的路由。 **VueRouter2.x**: Vue Router是Vue.js的官方路由库,它允许我们定义路由规则,根据URL的变化动态渲染...

    Nodejs包,含coffeescript、express等

    例如,你可以创建一个新的Express应用,定义路由,编写Coffeescript代码来处理这些路由的请求。Coffeescript的简洁语法可以使得代码更加清晰,而Express的灵活性则让你能够快速地搭建功能丰富的Web应用。 这个...

    nodejs+express+mongodb+bootstrap+jquery+ejs写的电影demo

    接着,你可以分析并理解项目结构,了解Express路由的配置、数据库模型的设计以及EJS模板的使用方法。同时,你还可以研究如何结合jQuery和Bootstrap来优化前端用户体验。最后,通过运行项目,你可以看到一个完整的...

    使用node.js+express+bootstrap+mongodb做简易的博客系统.zip

    在博客系统中,Bootstrap可以用来设计美观的用户界面,包括导航栏、文章列表、评论区等,确保在不同设备上都能良好显示。 MongoDB是一个文档型数据库,使用JSON格式的文档存储数据,非常适合处理结构灵活的数据。在...

    路由跳转.zip

    路由是控制应用程序导航和页面间交互的关键机制。当我们谈论“路由跳转”,我们通常指的是用户点击链接、表单提交或者程序逻辑触发时,如何在不同的页面或应用状态之间平滑地过渡。 在给定的文件“路由跳转.zip”中...

    使用Vue2.0+express+mongodb开发的完整博客系统.zip

    Vue Router用于管理应用的路由,实现页面间的导航。Vuex则作为状态管理工具,集中管理全局状态,确保组件间状态的一致性。 2. Express:Express是Node.js平台上的一个web应用框架,它简化了服务器端的HTTP路由、...

    详谈Angular路由与Nodejs路由的区别

    Express路由适合多页面应用,涉及实际的页面跳转。 2. 动态更新:Angular路由在前端更新内容,无需完整页面刷新;Express路由在后端生成内容,通过HTTP响应传递到客户端。 3. 控制权:Angular路由由客户端控制,用户...

    基于Express+vue的在线跑腿系统源码.zip

    - server目录:存放Express应用代码,包括路由、模型、中间件等。 - client目录:存放Vue项目,包括组件、路由、样式、脚本等。 - database配置:数据库连接配置文件,如MongoDB或MySQL。 - 其他配置文件:如.env...

    react+express+MongoDB完成的博客系统.zip

    在“demo_01”中,我们可以看到项目的具体组织结构,可能包括`client`(React前端代码)、`server`(Express后端代码)、`models`(Mongoose数据模型)、`routes`(Express路由配置)、`public`(静态资源目录)等...

    公司员工管理系统,vue+express+mongodb,一天速成的代写课设,无阅读代码意义。.zip

    8. 路由管理:Vue Router在前端负责页面跳转和导航,而Express的路由定义则处理后端的HTTP请求,两者共同实现系统的导航和页面逻辑。 9. 错误处理:为了提高系统的健壮性,项目可能包含错误处理机制,如Express的...

    基于Vue+Nodejs+Express在线购物商城设计源码案例设计.zip

    9. **前端路由(vue-router)**:Vue-router是Vue.js官方的路由管理器,用于实现页面的动态路由和导航,帮助用户在不同的视图之间切换。 10. **响应式布局**:考虑到不同设备的兼容性,前端设计很可能采用了响应式...

    node.js+express+mysql+分页+bootstrap+文件上传+基本新闻模板和后台管理

    开发者可以使用Express的路由和中间件来实现这些功能,同时配合MySQL进行数据操作。可以创建一个管理界面,允许管理员进行新闻管理操作。 9. **API设计**:项目可能包含前后端交互的API设计,如GET请求获取新闻列表...

    基于angular4和express聊天实例

    8. **前端路由**:Angular4的`RouterModule`允许在应用内部导航,可能有如`/chat`的路由,引导用户进入聊天页面。 9. **状态管理**:为了处理复杂的应用状态,可能会使用如ngrx/store这样的状态管理库,来存储和...

    从网站上学习到了路由的一系列代码

    在前端开发中,路由主要用于管理SPA的导航和页面间跳转,常见于React、Vue.js、Angular等现代JavaScript框架中。例如,在React中,`react-router-dom`库允许开发者定义URL模式与组件的映射,当用户改变URL时,相应的...

    Vue3+express+node.js+elementPlus+mysql+axios实现商城后台管理系统.zip

    vue-router是Vue的官方路由管理库,它帮助我们管理页面间的导航和状态。在电商系统中,它可以轻松地处理商品详情页、购物车、订单管理等各种页面间的跳转。 Vuex是Vue的状态管理库,它集中管理全局状态,使得状态在...

    快递库存:在Express中实践更多CRUD基础

    商店库存应用课程中的一个项目,创建一个小型库存应用程序以练习在Express中执行CRUD操作我学到的东西Express路由/设置的更多实践快速验证程序的更多实践要做的事情添加身份验证/授权自己检查一下下载/克隆存储库,...

    express-bootstrap:模板 NPM、Express、引导程序

    1. **快速启动**:使用 Express-Bootstrap 模板,开发者可以立即开始编写业务逻辑,因为基础结构已经准备就绪,包括设置静态文件路由、视图引擎配置和基本路由。 2. **响应式设计**:模板集成 Bootstrap,确保应用在...

Global site tag (gtag.js) - Google Analytics