- ExpressJS 教程
- ExpressJS - 主页
- ExpressJS - 概述
- ExpressJS - 环境
- ExpressJS - 你好世界
- ExpressJS - 路由
- ExpressJS - HTTP 方法
- ExpressJS - URL 构建
- ExpressJS - 中间件
- ExpressJS - 模板
- ExpressJS - 静态文件
- ExpressJS - 表单数据
- ExpressJS - 数据库
- ExpressJS - Cookie
- ExpressJS - 会话
- ExpressJS - 身份验证
- ExpressJS - RESTful API
- ExpressJS - 脚手架
- ExpressJS - 错误处理
- ExpressJS - 调试
- ExpressJS - 最佳实践
- ExpressJS - 资源
- ExpressJS 有用资源
- ExpressJS - 快速指南
- ExpressJS - 有用的资源
- ExpressJS - 讨论
ExpressJS - 路由
Web 框架以不同的路径提供 HTML 页面、脚本、图像等资源。
以下函数用于定义 Express 应用程序中的路由 -
app.method(路径,处理程序)
此方法可以应用于任何一个 HTTP 动词 – get、set、put、delete。还存在一种替代方法,该方法的执行与请求类型无关。
Path 是请求运行的路径。
Handler 是一个回调函数,当在相关路由上找到匹配的请求类型时执行。例如,
var express = require('express'); var app = express(); app.get('/hello', function(req, res){ res.send("Hello World!"); }); app.listen(3000);
如果我们运行应用程序并转到localhost:3000/hello ,服务器会在路由“/hello”处收到 get 请求,我们的 Express 应用程序会执行附加到该路由的回调函数并发送“Hello World!” 作为回应。
我们还可以在同一条路线上有多种不同的方法。例如,
var express = require('express'); var app = express(); app.get('/hello', function(req, res){ res.send("Hello World!"); }); app.post('/hello', function(req, res){ res.send("You just called the post method at '/hello'!\n"); }); app.listen(3000);
要测试此请求,请打开终端并使用 cURL 执行以下请求 -
curl -X POST "http://localhost:3000/hello"
Express 提供了一种特殊方法all ,用于使用相同的函数处理特定路由上的所有类型的 http 方法。要使用此方法,请尝试以下操作。
app.all('/test', function(req, res){ res.send("HTTP method doesn't have any effect on this route!"); });
该方法通常用于定义中间件,我们将在中间件章节中讨论。
路由器
像上面这样定义路由维护起来非常繁琐。为了将路由与我们的主index.js文件分开,我们将使用Express.Router。创建一个名为things.js的新文件并在其中键入以下内容。
var express = require('express'); var router = express.Router(); router.get('/', function(req, res){ res.send('GET route on things.'); }); router.post('/', function(req, res){ res.send('POST route on things.'); }); //export this router to use in our index.js module.exports = router;
现在要在我们的index.js中使用此路由器,请在app.listen函数调用之前输入以下内容。
var express = require('Express'); var app = express(); var things = require('./things.js'); //both index.js and things.js should be in same directory app.use('/things', things); app.listen(3000);
路由“/things”上的 app.use函数调用将Things路由器附加到此路由。现在,我们的应用程序在“/things”处收到的任何请求都将由我们的 things.js 路由器处理。things.js 中的“/”路由实际上是“/things”的子路由。访问 localhost:3000/things/ 您将看到以下输出。
路由器对于分离关注点并将代码的相关部分保持在一起非常有帮助。它们有助于构建可维护的代码。您应该在单个文件中定义与实体相关的路由,并使用上述方法将其包含在您的index.js文件中。