一、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!'發送給客戶端。