Express.js 中间件的执行顺序

Express.js 是一个流行的 Node.js web 框架,许多开发人员在前端程序员中使用它来构建 Web 应用程序。一个常见的任务是编写中间件来执行路由之间的特定操作。在本文中,我们将详细介绍 Express.js 中间件的执行顺序,为您提供深入的了解和学习,以及相关的指导意义。

什么是 Express.js 中间件?

中间件是一个函数,它可以访问 Express 请求对象(req),响应对象(res)和应用程序的下一个中间件函数。这个“下一个”是一个类似于递归的回调函数,它调用下一个中间件并在中间件链中执行。通常,它执行某些操作并将控制传递给下一个中间件函数。

在 Express 中,每个中间件都具有对应的路径和 HTTP 方法,它们可以绑定到路由上,例如:

------------ -------- ----- ---- ----- -
  -- ----------
--

在这个例子中,我们创建了一个 GET 路由,它与路径根目录("/")匹配,并绑定了一个中间件函数。

当 Express.js 应用程序收到请求时,它会执行路由上绑定的中间件函数。这些函数可以按照特定的顺序执行,我们可以设置许多条件来控制它们的行为。

在理解执行顺序之前,首先需要理解中间件链如何工作。每个中间件都必须调用 next() 函数来指示要执行下一个中间件。如果未调用 next(),那么将停止执行中间件链,并且不会执行下一个函数。让我们看下面的示例:

------------- ---- ----- -- -
  ------------------ ------------
--

------------- ---- ----- -- -
  ------------------- ------------
--

------------ ----- ---- ----- -- -
  ------------------ ---------
  --------------- --------
--

在这个例子中,我们定义了两个中间件和一个 GET 路由处理程序。当我们发送 GET 请求至"/"路径时,将会发生下面的流程:

  1. 第一个中间件被执行并向控制台输出 "First middleware"
  2. 第二个中间件被执行并向控制台输出 "Second middleware"
  3. GET 路由处理程序被执行并向控制台输出 "Route handler"
  4. 最终响应发送至客户端

从这个例子中,我们可以看到中间件链是从第一个中间件开始执行的,并且它们按照声明的顺序执行。GET 路由处理程序被视为最后一个中间件,它既不需要调用 next() 函数,也不能再执行其他中间件。

按条件控制中间件执行顺序

在 Express.js 中,我们可以按条件控制中间件的执行顺序。这些条件可以是:

  • 请求方法(如 GET、POST、PUT、DELETE 等)
  • PATH、URL、HTTP 请求头等
  • 其他自定义条件

我们可以使用以下方法将中间件绑定到特定的请求方法:

------------ ----- ---- ----- -- -
  ---------------- ---------
--

在这个例子中,我们向 / 路径的 GET 请求绑定了一个中间件函数。当我们向应用发送 GET 请求时,这个函数将被执行。

另外,我们还可以使用以下方法将中间件绑定到特定的 URL:

----------------- ----- ---- ----- -- -
  ------------------ ------------
--

在这个例子中,我们向 /admin 路径绑定了一个中间件。当我们向 /admin 发送请求时,这个函数将被执行。

还有一种使用 Express.js 中间件的方法是在请求处理程序中使用条件,例如:

-------------------- -------- ----- ---- ----- -
  -- -------------- --- ---- -------------
  ---- ------
-- -------- ----- ---- ----- -
  -------------------
--

-------------------- -------- ----- ---- ----- -
  -------------------
--

在这个例子中,我们创建了一个 GET 请求处理程序。如果请求参数 id 等于 0,那么将跳过第一个中间件并执行下一个,否则将执行第一个中间件。第一个中间件执行后,将执行第二个中间件并向客户端发送响应。

结论

Express.js 中间件是掌握 Web 开发的关键工具之一。在本文中,我们了解了中间件链的工作原理以及如何按照一定条件控制中间件的执行顺序。掌握中间件的执行顺序和使用技巧,可以帮助我们更好地构建复杂的 Web 应用程序。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/6711b57ead1e889fe20050ed


猜你喜欢

  • 详解 ECMAScript 2020 的 Promise.any() 和 Promise.allSettled() 方法

    在 ECMAScript 2020(简称 ES2020)中,Promise 类型新增了两个方法,分别是 Promise.any() 和 Promise.allSettled()。

    9 天前
  • 如何在 GraphQL 中构建快速响应的 API

    GraphQL 是一种被广泛应用于构建 API 的查询语言和运行时环境。其优点包括易于使用、高度可配置以及对客户端请求的灵活性等。然而,在创建 GraphQL API 时,要实现快速响应的API ,需...

    9 天前
  • 如何在 Fastify 中使用 JWT 进行身份认证

    在现代的 Web 应用中,身份认证是一项非常重要的功能。其中,JWT(JSON Web Token)是最常用的身份认证方案之一。它不仅可以用于身份认证,还可以用于授权和数据交换。

    9 天前
  • 在 CSS Grid 中如何设置可滚动的内容区域

    CSS Grid 是一个非常强大的 CSS 布局模块。最近,网站和应用程序越来越普遍地采用了这种布局模块。CSS Grid 可以轻松地创建非常复杂的布局,包括多个列和行,并可以控制每个单元格的大小和位...

    9 天前
  • 解决 TypeScript 中出现的 "TS2304: Cannot find name" 错误

    解决 TypeScript 中出现的 "TS2304: Cannot find name" 错误 TypeScript 是一种开源的 JavaScript 超集,它添加了可选的静态类型和其他语言特性,...

    9 天前
  • 如何制作一个 Material Design 风格的时间轴

    如何制作一个 Material Design 风格的时间轴 在前端开发中,时间轴总是一个非常有趣的元素,无论是展示时间流程还是展示历史事件,都非常有用。在 Material Design 的风格下,时...

    9 天前
  • 无障碍技术的演变及未来趋势

    无障碍技术 (Accessibility) 是指在 Web 应用开发过程中,为了提供更好的用户体验,去除系统中可能存在的一切障碍,使得视觉障碍、听觉障碍等残疾人士能够更加容易地使用 Web 应用。

    9 天前
  • Kubernetes 中如何应对 Pod 出现 liveness 探针失败问题

    在 Kubernetes 中,liveness 探针是一种用于检测 Pod 是否正常运行的机制。当 Pod 中的某个容器停止响应时,liveness 探针会检测到该情况并重启该容器,以保证 Pod 的...

    9 天前
  • Hapi.js 实战:如何测试你的路由

    在前端开发中,路由是一个重要的概念。它决定了你的应用程序如何响应不同的 URL 请求。Hapi.js 是一个流行的 Node.js 框架,它提供了方便的路由管理和测试工具。

    9 天前
  • Angular 应用中如何优化数据绑定

    Angular 是一款极其流行的前端框架,它采用数据绑定技术来实现各种复杂逻辑和交互。然而,数据绑定可能会成为应用性能问题的根源,因为它可能导致频繁的 DOM 操作和复杂的变化检测。

    9 天前
  • 如何在 Tailwind 中使用 CSS Grid?

    在前端开发中,CSS Grid 是一种非常强大的网格布局方式。使用 CSS Grid 可以轻松地创建灵活并响应式的布局,同时避免使用传统的 float 和 position 属性方式。

    9 天前
  • 如何在 LESS 中使用 px2rem?

    在前端开发中,移动端设备呈现的效果跟电脑端设备不同,基于这个问题,可以使用一些前端技术去解决这个问题,其中之一就是 px2rem。 什么是 px2rem? 在移动端开发中,我们往往会使用像素进行布局,...

    9 天前
  • GraphQL 在前端应用中的性能最佳实践

    GraphQL 是一种现代的 API 查询语言,相较于传统 RESTful API 更加灵活与高效。在前端应用中使用 GraphQL,可以提升应用的性能与用户体验。

    9 天前
  • 在 Koa 应用程序中使用 MongoDB 的技巧

    在现代的 Web 应用程序中,MongoDB 变得越来越流行,因为它是一个高性能、可扩展、面向文档的数据库。同时,Koa 是一个非常流行和被广泛使用的 Node.js 框架。

    9 天前
  • 使用 Mocha 测试框架测试 Django 应用程序!

    介绍 随着前端应用程序日益复杂,测试变得越来越重要。而 Mocha 是一种流行的 JavaScript 测试框架,它支持在浏览器和 Node.js 环境中运行,可以帮助我们编写清晰、跨浏览器的测试用例...

    9 天前
  • Socket.io 的安全问题及解决方法

    在现代 Web 应用程序中,实时通信是非常重要的。WebSockets 已经成为 Web 实时通信的标准,但是,它并非所有浏览器所支持。于是,Socket.io 应运而生,它提供了一种向所有浏览器广泛...

    9 天前
  • 如何使用 PM2 自动化 Node.js 应用的部署?

    什么是 PM2? PM2 是一个流行的 Node.js 进程管理工具,它可以轻松地管理和监控您的 Node.js 应用程序。使用 PM2,您可以: 管理您的 Node.js 应用程序进程,开启/关闭...

    9 天前
  • SSE 技术与 WebSocket 技术的异同与优缺点分析

    SSE 技术和 WebSocket 技术都是前端实现推送服务的方式,二者虽然有一定的相似之处,但也存在一些本质的区别。本文将通过对二者的异同及其优缺点的分析,为开发者提供一些有深度的学习和指导意义。

    9 天前
  • Chai-Enzyme:结合使用 Chai 和 Enzyme 进行 React 组件测试

    React 组件测试是前端开发中必备的工作之一,它可以确保组件的稳定性和正确性,也可以节省开发者的时间和精力。在众多的测试工具中,Chai 和 Enzyme 是两个非常流行的测试库,它们可以结合使用,...

    9 天前
  • 前端性能优化的关键指标

    前端性能优化是一个综合性的技术难题,开发者需要在多个层面进行优化,以同时提高网站访问速度和用户体验。在优化前端性能的过程中,开发者需要关注一些关键指标。本文将介绍这些关键指标,以及如何根据它们来分析和...

    9 天前

相关推荐

    暂无文章