一、router.get用法
router.get是Express.js框架中定义路由的方法之一,用于定义HTTP GET请求的路由。router.get函数的语法如下:
router.get(path, callback [, callback ...]);
其中,path参数是一个字符串,指定URL路径,callback参数是处理请求的回调函数。当请求路径与path参数匹配时,会执行回调函数。如果有多个回调函数,则按照顺序依次执行。
举个例子,以下代码定义了一个基本的路由:
const express = require('express');
const app = express();
// GET路由
app.get('/', (req, res) => {
res.send('Hello World!');
});
app.listen(3000, () => {
console.log('Example app listening on port 3000!');
});
上面代码中,当客户端访问'/'路径时,会发送'Hello World!'给客户端。
二、router.get用法 Node.js
router.get函数是Express.js框架中基于Node.js的HTTP模块实现的。HTTP模块是Node.js的核心模块,用于实现HTTP服务器和客户端。
使用Express.js框架中的router.get函数,开发者可以更加简便地定义HTTP请求路由,无需手动编写HTTP模块的代码。
在上面的例子中,我们使用了Express.js框架的get方法,而不是使用Node.js的HTTP模块的get方法,不过,它们的核心思想是相同的:当客户端向服务器发送GET请求时,服务器会响应客户端的请求。Express.js框架只是在这个过程中为开发者提供了更加便捷的API,让开发者可以更加轻松地定义路由。
三、router.get的作用
1、定义路由
router.get函数的主要作用是用于定义HTTP GET请求的路由。通过使用该函数,开发者可以轻松地定义路由与回调函数的对应关系,当有请求来访问该路由时,会自动调用回调函数进行处理。
下面代码示例定义了两个路由:
const express = require('express');
const app = express();
// GET路由
app.get('/', (req, res) => {
res.send('Hello World!');
});
// GET路由
app.get('/about', (req, res) => {
res.send('About Page');
});
app.listen(3000, () => {
console.log('Example app listening on port 3000!');
});
当访问'/'路径时,将会发送'Hello World!'给客户端,当访问'/about'路径时,将会发送'About Page'给客户端。
2、处理URL参数
在路由中,URL参数是指由':'开头的字符串。在回调函数中,可以通过req.params来获取URL参数的值。
下面代码示例定义了一个带有URL参数的路由:
const express = require('express');
const app = express();
// GET路由
app.get('/user/:id', (req, res) => {
res.send('User ID: ' + req.params.id);
});
app.listen(3000, () => {
console.log('Example app listening on port 3000!');
});
当访问'/user/123'路径时,将会发送'User ID: 123'给客户端。
3、处理请求参数
除了处理URL参数外,还可以通过req.query获取GET请求中的查询参数。查询参数是指问号'?'后面的字符串。
下面代码示例定义了一个带有查询参数的路由:
const express = require('express');
const app = express();
// GET路由
app.get('/user', (req, res) => {
const name = req.query.name;
const age = req.query.age;
res.send('Name: ' + name + ', Age: ' + age);
});
app.listen(3000, () => {
console.log('Example app listening on port 3000!');
});
当访问'/user?name=Tom&age=18'路径时,将会发送'Name: Tom, Age: 18'给客户端。
4、使用中间件
在路由中,还可以使用中间件函数,对请求做进一步的处理。中间件函数是路由处理函数的一种扩展,可以增加路由的处理能力。
下面代码示例定义了一个带有中间件的路由:
const express = require('express');
const app = express();
// 中间件函数
const logger = (req, res, next) => {
console.log('Time:', Date.now());
next();
}
// GET路由
app.get('/', logger, (req, res) => {
res.send('Hello World!');
});
app.listen(3000, () => {
console.log('Example app listening on port 3000!');
});
当访问'/'路径时,会首先执行logger中间件函数,输出当前时间,再执行路由回调函数,将'Hello World!'发送给客户端。
5、使用多个处理函数
在路由中,还可以使用多个处理函数,在需要处理多种任务时更加灵活。在路由处理函数中,可以使用next函数将控制权交给下一个处理函数。
下面代码示例定义了一个带有多个回调函数的路由:
const express = require('express');
const app = express();
// 中间件函数1
const middleware1 = (req, res, next) => {
console.log('Middleware 1');
next();
}
// 中间件函数2
const middleware2 = (req, res, next) => {
console.log('Middleware 2');
next();
}
// GET路由
app.get('/',
middleware1,
middleware2,
(req, res) => {
res.send('Hello World!');
});
app.listen(3000, () => {
console.log('Example app listening on port 3000!');
});
当访问'/'路径时,会先执行middleware1中间件函数,输出'Middleware 1',再执行middleware2中间件函数,输出'Middleware 2',最后执行路由回调函数,将'Hello World!'发送给客户端。