IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 下班前几分钟,Express 快速入门 -> 正文阅读

[JavaScript知识库]下班前几分钟,Express 快速入门

目录

一、Express 简介

二、Express 快速入门

安装

启动

项目生成器

三、Express 基本路由

概念

使用

四、Express 中间件

概念

使用

更多


一、Express 简介

基于?Node.js?平台,快速、开放、极简的 Web 开发框架。

Web 应用程序

Express 是一个保持最小规模的灵活的 Node.js Web 应用程序开发框架,为 Web 和移动应用程序提供一组强大的功能。

API

使用您所选择的各种 HTTP 实用工具和中间件,快速方便地创建强大的 API。

性能

Express 提供精简的基本 Web 应用程序功能,而不会隐藏您了解和青睐的 Node.js 功能。

框架

许多?流行的开发框架?都基于 Express 构建。

二、Express 快速入门

安装

1、首先假定你已经安装了?Node.js,接下来为你的应用创建一个目录,然后进入此目录并将其作为当前工作目录。我已创建 express-project。

2、进入项目,npm init,“回车”默认设置,在遇到

entry point: (index.js)

习惯性将 index.js 改成 app.js,表示当前应用的入口文件。如果你希望采用默认的文件名,只需按“回车”键即可,之后会生成?package.json。

3、接下来在 express-project 下安装 Express 并将其保存到依赖列表中

npm install express --save

启动

1、在项目中,新建 app.js

const express = require('express')
const app = express()

app.get('/', (req, res) => {
  res.send('Hello World!')
})

app.listen(3000, () => {
  console.log("启动成功!")
})

2、启动项目

node app.js

3、在浏览器打开 localhost:3000,返回?Hello World!

到这里,一个 Express 项目就顺利搭建起来了。

Express 项目生成器

除了以上方式,你还可以通过应用生成器工具 express-generator 可以快速创建一个应用的骨架。

npm install -g express-generator

express-generator 安装完成之后,可以使用 express 快速创建一个新项目。

express my-app

创建完成之后,终端给出步骤提示

进入项目 - 安装依赖 - 启动项目。

同样的,浏览器访问?localhost:3000(项目默认启动端口为3000)

?

三、Express 基本路由

概念

在上面的例子中,我们使用

app.get('/', function (req, res) {
  res.send('Hello World!')
})

其实这就是一个基本路由。在 Express 中,路由指的是客户端的请求与服务器处理函数之间的映射关系。?

Express 中的路由由?3 部分组成,分别是请求的类型、请求的 URL 地址、处理函数

app.METHOD(PATH, HANDLER)

例如:

app.get('/', function (req, res) {
  res.send('Hello World!')
})

app.post('/', function (req, res) {
  res.send('Got a POST request')
})

app.get('/user', function (req, res) {
  res.send('Got a GET request at /user')
})

app.post('/user', function (req, res) {
  res.send('Got a POST request at /user')
})

使用

1、最基本用法,就是把路由挂载到 app 上

?

2、稍微复杂一点的就是模块化路由,为了方便对路由进行管理,不建议将路由直接挂载到 app 上,而是推荐将路由抽离为单独的模块。

主要有以下几个步骤:

(1)创建路由模块对应的 .js 文件

(2)调用 express.Router() 创建路由对象

(3)向路由对象上挂载具体的路由

(4)使用 module.exports 向外共享路由对象

(5)使用 app.use() 函数注册路由模块

?

在 app.js 中注册路由模块

?

13 行表示在匹配到 url 有 /users 时,继续使用?usersRouter?路由模块匹配规则,usersRouter 中有对 /show 进行匹配,此时当我们访问 localhost:3000/users/show?

?

成功拦截,返回信息。

当然你也可以不为路由模块添加前缀或者添加更长的前缀

app.use(usersRouter)   // 此时匹配 localhost:3000/show

app.use('/my/users',usersRouter)   // localhost:3000/my/users/show

四、Express 中间件

概念

中间件(Middleware ),特指业务流程的中间处理环节。说白了就是一堆方法,接收客户端发来费请求,可以对该请求做出响应,也可以继续交给下一个中间件进行处理。

主要由两部分组成:中间件方法、请求处理函数。

使用

1、对特定 url 使用中间件(局部中间件)

app.get('/users', (req, res, next) => {
  console.log("进入中间件!")
  next();   // 向下执行
})

app.get('/users', (req, res)=> {
  res.send("Hello World!")
})

2、使用 app.use,可设置全局生效的中间件

// 接收所有的请求的中间件(全局生效)
app.use((req, res, next) => {
  console.log('请求进入 app.use 中间件!')
  next()
})

// 当客户端访问 /users 请求的时候走当前中间件
app.use('/users', (req, res, next) => {
  console.log('请求进入 app.use /users 中间件!')
  next()
})

app.get('/users', (req, res)=> {
  res.send("Hello World!");
})

访问 /users,

???

??

使用中间件应该注意:

(1)一定要在路由之前注册中间件

(2)客户端发送过来的请求,可以连续调用多个中间件进行处理

(3)执行完中间件的业务代码之后,不要忘记调用 next() 函数

(4)为了防止代码逻辑混乱,调用 next() 函数后不要再写额外的代码

?(5)连续调用多个中间件时,多个中间件之间,共享 req 和 res 对

3、错误处理中间件

app.get('/', (req, res) => {
  throw new Error('正在维护!')
})
// catch 404 and forward to error handler
app.use((req, res, next) => {
  next(createError(404))
})

访问一个不存在的 url?

更多

中间件详细内容请参考:Using Express middleware - Express 中文文档 | Express 中文网?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-21 21:27:19  更:2022-07-21 21:30:07 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 12:44:06-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码