久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

Express框架定制路由實(shí)例分析

瀏覽:216日期:2022-06-09 15:30:54

1、序言

  上一節(jié)快速搭建Express開發(fā)系統(tǒng)步驟,對(duì)如何使用express-generator創(chuàng)建一個(gè)WEB項(xiàng)目進(jìn)行了說明,本節(jié)我們會(huì)對(duì)這個(gè)項(xiàng)目的代碼進(jìn)行分析,完成一個(gè)路由功能的開發(fā)。涉及的知識(shí)點(diǎn)有以下幾個(gè):

  1. 開發(fā)一個(gè)路由模塊(可以支持get和post請(qǐng)求)
  2. 測(cè)試(get請(qǐng)求用瀏覽器驗(yàn)證、post請(qǐng)求呢,我就用postman簡(jiǎn)單處理一下,因?yàn)楸竟?jié)課程沒有想去講web端post請(qǐng)求的知識(shí),后續(xù)有機(jī)會(huì)單獨(dú)講解吧)

2、開發(fā)一個(gè)路由模塊

  在上一篇文章中講到,我們以http://localhost:3000/system 路由為例,制作它的get和post請(qǐng)求路由。步驟如下:

2.1 在routes目錄下創(chuàng)建system.js文件

代碼內(nèi)容如下

var express = require("express");var router = express.Router();// get routerrouter.get("/", function(req, res, next) {    res.send("<p>這是get請(qǐng)求/system返回的資源</p>")});// post routerrouter.post("/:id", function(req, res, next) {    var id = req.params.id;  //注意這里的id是/:id指定的路由參數(shù)    var name = req.body.name;    var tel = req.body.tel;    res.json({status:"ok",message:"你發(fā)送的內(nèi)容("+ id + "、" + name + "、" + tel +")服務(wù)器已經(jīng)收到"    });});module.exports = router;

  解釋一下,router.get用于響應(yīng)http的get請(qǐng)求,router.post用于響應(yīng)http的post請(qǐng)求。我們?cè)诘谌糠烛?yàn)證時(shí),分別會(huì)通過瀏覽器和postman分別來對(duì)/system路由發(fā)起get和post請(qǐng)求。
  此外,/:id這部分會(huì)映射到用戶的url請(qǐng)求路徑中,如你的請(qǐng)求鏈接是http://localhost:3000/system/2402040134,那么在post的處理函數(shù)中,會(huì)將:id匹配到2402040134這個(gè)值,相當(dāng)于是一個(gè)url參數(shù)。同時(shí),要注意,在代碼中獲取id的值時(shí),使用的是req.params這個(gè)對(duì)象。不可與req.body混淆。

2.2、如何使路由模塊生效

  不過,目前這個(gè)代碼還沒有被注冊(cè)到/system路徑下,接下來我們需要在app.js中添加幾行代碼。

  注:在app.js中第9行引入我們的system.js模塊,第24行,將這個(gè)模塊注冊(cè)在/system路徑上。

3、測(cè)試驗(yàn)證

  在vs code中沒有顯示powershell控制臺(tái)時(shí),可以使用ctrl+` 喚醒。然后輸入npm start,啟動(dòng)我們的項(xiàng)目。

3.1 驗(yàn)證router.get

  這里我們通過瀏覽器訪問/system,就可以執(zhí)行到router.get后邊的方法,看看是否會(huì)得到預(yù)期的返回(是一段Html內(nèi)容)。

3.2 驗(yàn)證router.post

  安裝postman的過程我不在這里描述了,大家自行安裝一下。以下截圖是我請(qǐng)求界面的信息及驗(yàn)證結(jié)果。

  注意,在上圖中url中的2402040134即路由參數(shù),下方的name和tel是post的請(qǐng)求body內(nèi)容。最后,可以看到,返回了我們預(yù)期的json內(nèi)容。

4、總結(jié)

  內(nèi)容不是很復(fù)雜,寫得比較簡(jiǎn)單,為了方便初學(xué)的朋友跟著練習(xí)。當(dāng)然,不忘預(yù)告一下,下一章節(jié)我會(huì)以本文中提到的router.get請(qǐng)求為重點(diǎn),引入ejs模板的使用,讓大家可以通過res對(duì)象,通過數(shù)據(jù)+模板的方式,完成服務(wù)器端渲染生成頁面。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 牙克石市| 阳朔县| 吉安县| 襄樊市| 镶黄旗| 剑河县| 柳林县| 兖州市| 罗定市| 南郑县| 蚌埠市| 齐齐哈尔市| 佛坪县| 桦川县| 公主岭市| 黄骅市| 广元市| 上饶市| 桓仁| 化德县| 桃源县| 邻水| 宝鸡市| 克拉玛依市| 和田县| 闵行区| 盖州市| 尚志市| 河西区| 瑞丽市| 祁东县| 通辽市| 东乡| 黄山市| 临湘市| 漳州市| 屯昌县| 彭山县| 宁强县| 达州市| 弋阳县|