Express.js 中的静态文件服务:使用 Express.static

Express.js 是一个流行的 Node.js web 应用框架,通过提供众多的中间件和函数,Express 让开发者更容易地创建、配置、管理和调试复杂的服务器端应用。其中一个非常重要的功能就是静态文件服务。

在 Web 开发中,静态文件通常是指 HTML、CSS、JavaScript、图片、音频、视频等资源,它们不需要服务器处理或查询数据库,直接通过 URL 地址访问即可。Express.js 提供了一个方便的中间件函数 Express.static,可以让我们轻松地将静态文件托管到服务器端,实现快速、可靠、可缓存的静态文件服务。

Express.static 的基本用法

Express.static 函数是一个 Express 应用程序级别的中间件函数,可以将包含静态文件的目录作为参数传递,并返回一个真正的中间件函数。这个中间件函数能够处理 HTTP 的 GET 请求,并自动为请求文档匹配文件系统上的文件,如果找到了对应的文件,就将其发送到客户端。如果没有找到,Express.static 通常会将请求转发给下一个中间件处理。

Express.static 函数的基本用法非常简单,只需要在应用程序中使用 app.use 调用即可:

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

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

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

上面的代码首先创建了一个 Express 应用程序实例,并使用 app.use 调用将当前目录下的 public 目录作为静态文件目录。然后启动服务器监听在 3000 端口上。现在,我们可以在浏览器中访问 public 下的任何文件了。例如,如果 public 目录下有一个名为 index.html 的文件,我们可以通过访问 http://localhost:3000/index.html 来访问该文件。

需要注意的是,这里使用了相对目录 public,这意味着我们必须将静态资源文件放置在当前目录下的 public 目录中,或者使用绝对路径或其他相对路径指定目录。

Express.static 的高级用法

除了基本用法之外,Express.static 还支持许多高级配置选项,可以进一步细化静态文件服务的行为。以下是一些常用的选项:

  • 选择 MIME 类型

    默认情况下,Express.static 会试图根据文件扩展名自动选择正确的 MIME 类型。如果需要手动指定 MIME 类型,可以通过以下方式:

    -------------------------------- - --------------- ----------- ----
  • 指定缓存控制

    静态文件通常可以进行缓存,这样可以减少服务器和客户端之间的通信次数。Express.static 提供了 cacheControl 选项,可以指定客户端缓存的策略。例如,下面的代码将缓存资源1年,并使用最新的版本:

    -------------------------------- - ------- ----- ----- ------ ------------- ----- ----
  • 自定义文件查找算法

    默认情况下,Express.static 将为每个静态文件请求依次查找目录中的文件,如果找到了就会发送它。如果你需要自定义查找算法,例如忽略某些文件、处理文件别名等,可以提供一个自定义的查找函数。例如,下面的代码将在查找文件之前,将样式文件路径中的 ~ 替换为根目录:

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

总结

本文介绍了如何使用 Express.static 快速并方便地为 Express.js 应用程序提供静态文件服务。我们讨论了 Express.static 的基本用法和高级用法,包括 MIME 类型选择、缓存控制、自定义查找算法等。希望本文能够帮助读者更好地理解和应用 Express.js 中的静态文件服务,以提高 Web 开发的效率和质量。

示例代码

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

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

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

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

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


猜你喜欢

  • Babel 编译 ES6 代码时无法识别箭头函数怎么办?

    随着前端开发技术的不断更新,ES6 已经成为了前端开发中的主要技术之一。然而,由于一些旧的浏览器版本不支持 ES6,我们需要通过编译工具 Babel 将 ES6 代码转换成 ES5 代码。

    1 年前
  • MongoDB 中的 mapReduce 详解

    什么是 mapReduce? mapReduce 是一种在 MongoDB 数据库中执行聚合操作的方法。它允许用户定义一些 JavaScript 函数,这些函数将被应用于数据库集合中的文档,并按照某些...

    1 年前
  • SASS 中 HSL 和 RGB 颜色之间的转换

    SASS 中 HSL 和 RGB 颜色之间的转换 在前端开发中,我们常常需要使用颜色来为页面着色。而在 SASS 中,我们可以使用 HSL(色相、饱和度、亮度)和 RGB(红、绿、蓝)这两种颜色格式来...

    1 年前
  • 如何使用 RESTful API 进行文件上传和下载操作

    在 WEB 开发中,文件上传和下载是非常常见的功能,本文将介绍如何使用 RESTful API 进行文件上传和下载操作。 什么是 RESTful API? REST(Representational ...

    1 年前
  • ES8 中新增的标准:Async Iteration

    在现代 Web 开发中,异步编程已经成为前端开发中的基本要求。为了更好的支持异步编程,JavaScript 语言也不断地添加了各种使用场景的新特性。ES8 中,引入了 Async Iteration ...

    1 年前
  • Material Design 中常见的 Notification 推送样式总结

    随着移动互联网的发展,Notification 推送成为了移动应用中不可或缺的一部分。在 Material Design 中,Notification 推送也有着自己的一套设计准则。

    1 年前
  • 如何在 React SPA 中集成 Ant Design 图标库

    Ant Design 是一个非常流行的 UI 库,是由阿里巴巴集团推出的一套优秀的设计语言和组件库。在 Ant Design 中,图标库也是非常重要的一部分,为网站添加视觉上的优秀效果提供了很大帮助。

    1 年前
  • 如何在 Serverless Framework 中引用外部 Node.js 模块?

    Serverless Framework 是一款通过 AWS Lambda 服务快速构建无服务器应用的框架,它支持 Node.js 开发者在 AWS Lambda 上构建、部署和运行应用程序。

    1 年前
  • Angular 中 RxJS 常用操作符使用技巧介绍

    在 Angular 中,RxJS 是一个非常有用而强大的工具库,它为我们提供了丰富的、函数式的响应式编程工具,这使得我们能够更加优雅的处理异步事件,并组织我们的代码以更好的复用并减少业务逻辑间代码的耦...

    1 年前
  • 如何解决 PWA 应用在 Android 中不能退出的问题?

    PWA 是指 Progressive Web App,是一种使用 Web 技术构建的应用程序,并具有类似于 Native app 的用户体验。由于 PWA 具有不需要从应用商店下载的优点,因此它们变得...

    1 年前
  • Sequelize 模块的初始化流程分析

    Sequelize 是一个 Node.js 中用于操作关系型数据库的 ORM(Object-Relational Mapping)框架,其提供了一种非常方便且易于维护的方式来操作数据库。

    1 年前
  • Kubernetes 中的容器亲和和反亲和

    在 Kubernetes 集群中,容器亲和和反亲和是非常重要的概念。容器亲和指定了哪些容器应该在同一个节点上运行,反亲和指定了哪些容器不应该在同一个节点上运行。了解容器亲和和反亲和可以帮助我们更好地调...

    1 年前
  • Koa 框架中使用 fs-extra 进行文件操作的方法指南

    Koa 是一种现代的 Web 应用程序框架,通过它可以快速构建强大而高效的 Web 应用程序,而 fs-extra 是一个对 fs 模块进行了扩展的 Node.js 模块,提供了更多的功能,比如对目录...

    1 年前
  • Tailwind 中如何处理字号与行高的问题

    引言 在前端开发中,字体一直都是一个重要的关注点。在设计中,字号和行高是常常被设计师考虑的。但是在前端开发中,却很少对它们进行处理。今天我们将介绍如何在 Tailwind 中有效处理字号和行高问题。

    1 年前
  • Deno 中如何使用 ES6 的 import/export 语法进行模块管理

    随着 JavaScript 的发展,模块化已经成为了前端开发必不可少的一部分。以前,我们只能使用 CommonJS 或者 AMD 这两种 module 格式,但是现在 ES6 已经把模块化纳入了语言标...

    1 年前
  • 利用 LESS 编写清晰易懂的 CSS 代码

    CSS 作为前端开发中重要的一环,其代码的可读性和可维护性对于整个项目的成功至关重要。LESS 作为一种 CSS 预处理器,为前端开发提供了更多的功能和便利,同时也可以帮助我们编写更加清晰易懂的 CS...

    1 年前
  • Jest 测试 React 中 connect 函数的使用方法

    在 React 应用中使用 connect 函数来连接组件和 Redux store 是一种常见的模式。connect 函数接收两个参数:mapStateToProps 和 mapDispatchTo...

    1 年前
  • ES9 中的 import() 函数详解及其实践应用

    随着前端技术的发展,模块化已成为前端开发中不可或缺的一部分,而 ES6 中引入的模块化语法已经为我们提供了便捷的模块化方式。但是在某些场景下,我们希望根据条件动态加载模块,这个时候就需要用到 ES9 ...

    1 年前
  • GraphQL 在 Elasticsearch 中的应用

    GraphQL 是一种由 Facebook 开发的 API 查询语言,它提供了一种更高效、更灵活、更精确的数据查询方式,让前端开发人员可以根据他们的需要动态查询和获取数据,从而改善前端应用程序的性能和...

    1 年前
  • Cypress 如何模拟多个浏览器进行集群测试?

    随着现代 Web 应用程序的复杂性和用户需求的不断增加,前端开发和测试变得越来越重要。Cypress 是一种基于 JavaScript 的前端测试框架,是一种功能强大、易于使用的工具,可以帮助开发人员...

    1 年前

相关推荐

    暂无文章