如何使用 Express.js 实现 PDF 文件生成和下载

前言

在前端开发中,经常需要将数据以 PDF 格式的文件进行保存和分享。本文将介绍如何使用 Express.js 库快速地生成并下载 PDF 文件。

准备工作

在开始正式代码编写之前,需要安装以下几个模块:

  • express:一个处理 HTTP 请求的库。
  • pdfmake:一个快速生成 PDF 文件的库。

运行以下命令进行安装:

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

编写代码

在创建 Express 应用的主文件 app.js 中,我们首先需要引入依赖的模块:

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

接下来需要配置 pdfmake,注意:在此期间需要进行中英文的映射。

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

其中 font 属性用于设置字体,需要首先在项目中准备好字体文件,放置在 fonts 目录下,这里使用了 Roboto 字体。lang 属性用于指定语言为中文。

接下来,我们使用 express.Router() 创建一个路由器实例,并在其中编写生成 PDF 文件的代码。

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

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

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

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

这里我们定义了一个 POST 请求 /generate-pdf,其中形参 req.body.username 表示用户名,用于在 PDF 文件中展示。docDefinition 对象表示 PDF 文件的内容,包含了标题和相关信息。res.setHeader('Content-Type', 'application/pdf'); 表示返回的文件类型为 PDF 格式,使用 res 对象将 PDF 文件返回给前端。

客户端代码

在 HTML 页面中设置一个表单,填写用户信息并点击按钮生成 PDF 文件。代码如下:

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

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

这里使用了 XHR 对象进行 POST 请求,并将请求的数据格式设置为 JSON 格式。在返回的 PDF 文件中,我们使用 Blob 对象将其转化为二进制数据类型,并将其通过创建一个 <a> 元素的 URL 属性使其可以被浏览器下载保存。

总结

使用 Express.js 和 pdfmake 库,可以快速地生成并下载 PDF 格式的文件,实现了数据的可视化和分享。本篇文章详细介绍了如何使用 PDFmake 库生成 PDF 文件并通过 Express.js 进行传输,同时也展示了如何在客户端进行下载。通过学习这些内容,希望读者可以在实际项目中实现 PDF 文件的生成和分享。

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


猜你喜欢

  • Serverless 架构中使用邮件通知遇到的问题及解决方案

    Serverless 架构中使用邮件通知遇到的问题及解决方案 随着 Serverless 架构在前端领域的不断普及,越来越多的开发者开始使用 Serverless 架构来构建应用程序。

    9 个月前
  • Chai-Webpack 插件:如何结合使用

    前言 在前端开发中,一般会使用 Webpack 来构建项目并打包代码,而在测试过程中,通常会使用 Chai 来进行断言。那么如果能结合使用 Chai 和 Webpack,将测试和打包集成在一起,不仅能...

    9 个月前
  • Headless CMS 的 API 规范与接口文档编写指南

    在现代 web 开发中,Headless CMS 是一种越来越流行的架构模式,它可以帮助开发者更加灵活地为前端应用提供动态内容。 而 Headless CMS 的核心是其 API 接口,良好的 API...

    9 个月前
  • 浅析 Babel 处理 ES6 编译转换

    随着前端技术的不断更新迭代,ES6 (ECMAScript 2015) 成为了开发中备受关注的一个版本。ES6 提供了许多前所未有的新特性和语法糖,如箭头函数、解构赋值、类、模板字符串等等。

    9 个月前
  • 如何使用 Material Design 中的 SearchView

    在现代用户界面中,搜索功能变得越来越重要。Material Design 中的 SearchView 提供了一种流畅、美观的搜索体验。SearchView 不仅可以用在 Android 应用中,也可以...

    9 个月前
  • Hapi 和 Sequelize 实现 MySQL 和 PostgreSQL 数据库操作

    前言 在开发 Web 应用时,经常需要使用数据库来存储和处理数据。而 Hapi 和 Sequelize 是目前前端开发领域中比较流行的工具之一,可以帮助我们轻松实现对 MySQL 和 PostgreS...

    9 个月前
  • ES6 中 Proxy 用于快捷处理表单数据的实际应用

    在前端开发过程中,表单数据的处理是必不可少的一环。ES6 中的 Proxy 对象提供了一种便捷且强大的方式来处理表单数据。本文将详细介绍 Proxy 的基本原理和实际应用,并提供示例代码以供学习和参考...

    9 个月前
  • Fastify 插件的使用

    Fastify 是一款快捷高效的 Node.js Web 应用框架,它提供了插件化的体系结构以便于你快速的构建高性能的 REST APIs 或者 Web 应用。在本文中,我们将介绍 Fastify 插...

    9 个月前
  • 如何使用 PWA 提升 Web 应用的用户体验

    什么是 PWA? PWA(Progressive Web Apps)是一种使用现代 Web 技术构建的应用程序,可以在各种设备上运行,并具有本地应用程序的用户体验。

    9 个月前
  • 使用 Jest 的 snapshot 功能解决可视化 UI 组件开发中的样式问题

    在前端开发中,UI 组件开发是一个重要的部分。但是,开发一个良好的 UI 组件需要考虑很多因素,其中样式问题是一个关键的问题。在可视化组件开发中,为了保证组件的样式效果,我们需要不断进行样式文件的修改...

    9 个月前
  • 实现 ES10 的静态方法 String.matchAll 提升字符串匹配性能

    在 ES10 中,新增了一个静态方法 String.matchAll(),该方法可以返回一个迭代器,用于匹配一个字符串中所有与正则表达式匹配的子串。这个新特性可以显著提高 JavaScript 中字符...

    9 个月前
  • 如何正确使用 CSS Reset 提升网站性能

    在前端开发中,CSS Reset 是优化网站性能的重要手段之一。它可以将不同浏览器默认样式之间的差异化削减到最小程度,消除一些不必要的浏览器兼容问题,从而大大提升网站的整体性能和兼容性。

    9 个月前
  • ES8 中的 Object.getOwnPropertyDescriptors() 解决 JavaScript 对象拷贝问题

    在 JavaScript 中,对象拷贝是一项常见的操作,我们可以使用 Object.assign() 方法来完成对象的浅拷贝。但是,在实际开发中,我们常常需要进行深拷贝,即拷贝对象的所有属性,包括嵌套...

    9 个月前
  • RESTful API 中的版本控制方案介绍

    在前端开发中,RESTful API 是非常常用的一种技术,在实际开发中,可能会遇到代码版本的问题,比如接口升级、业务需求变更等。所以,对于RESTful API的版本控制非常的重要。

    9 个月前
  • Angular Flex 介绍和实战

    Angular Flex 是一个针对 Angular 框架的 CSS 库,用于创建灵活和响应式的布局和 UI 组件。Angular Flex 基于 Flexbox 布局模型,提供了一组可复用的 CSS...

    9 个月前
  • ES7 基础:Set 和 Map 集合详解

    本文将介绍 ES7 中新增的 Set 和 Map 集合,包括其定义和基本使用方法,并且会分别介绍 Set 和 Map 的不同特性和应用场景。最后,本文还会提供一些示例代码和学习建议。

    9 个月前
  • Redux 代码规范校验:ESLint + Prettier

    在前端开发中,代码规范是非常重要的,它能够提高代码的可读性、可维护性和可扩展性。同时,为了保持团队协作的一致性,代码规范一般会制定成为约定俗成的技术规范。因此,我们需要一个工具来帮助我们进行代码规范的...

    9 个月前
  • 常用的 Node.js ORM 库一览

    在 Node.js 中,ORM(Object-Relational Mapping)库可以帮助我们将关系型数据库和面向对象编程语言之间的联系嵌入到应用程序中,从而更加方便地操作数据库。

    9 个月前
  • 搭建 React + Webpack 项目,两种大型工程实现方案比较

    React是一个非常流行的Javascript库,它的高度组件化特性、高度可靠及更为高效的虚拟Dom机制让Web开发更加容易、简单,同时也能在很多方面上提升用户体验。

    9 个月前
  • Server-sent Events(SSE) 应用实例分享:实时世界杯比分更新

    前言 在 Web 开发中,实时应用是一种非常有用的技术,它可以让用户在不刷新页面的情况下获取新的数据或者事件。Server-sent Events (SSE) 是一种实现这种实时应用的协议,它可以让服...

    9 个月前

相关推荐

    暂无文章