前端使用jsPdf导出pdf文档

2023-10-09 16:58

本文主要是介绍前端使用jsPdf导出pdf文档,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近遇到一个需求,就是要把几个页面的数据汇总一下生成pdf报表(当然数据是后端封装好的),于是乎第一时间想到了 jspdf,但是也踩了不少坑,尤其是它竟然不支持中文.
先上点代码…
1.安装jspdf
javascript 代码

npm install -S jspdf

2.安装完毕后,在要使用的组件导入jsPDF(以vue为例)
javascript 代码

import jsPDF from 'jspdf';
let doc = new jsPDF();

3.设置一下字体
1) getFontList 获取所有可用字体列表 (但是没有中文)
2) addFont 添加字体
3) setFont 设置字体 (经测试添加中文字体并不可用)
4) 具体还是去github上看文档吧
4 使用jspdf 创建文档,来一个简单的小demo
javascript 代码

doc.text('Hello jsPDF', 10, 10);
doc.save('test.pdf');

5.中文问题不解决,还是用不了啊,最后找到了另一个包 (jsPDF-CustomFonts-support),该包核心还是jspdf,只不过进行了扩展,允许我们自定义字体.
它最大的问题在于一共需要加载7个js文件,其中一个是一个比较大的字体文件.
还是先说说怎么加载自定义字体来解决中文乱码问题吧
1) 按照这个文档载入必须的js文件
2) 打卡最后的js文件也就是(vfs_fonts.js),里面返回一个对象,这个对象就是字体文件的base64编码
3) 如果不需要这个字体的话,可以将里面的字体base64编码删干净,找一个中文字体(比如 微软雅黑.ttf),首先可以把字体文件压缩一下(效果不大),将该字体文件转为base64编码
4) 将转化好的base64编码放到刚才说的return 对象里面,键名可以自己定义,键值就是改字体编码
5) 然后添加字体,设置字体,跟上文提到的API一致
javascript 代码

doc.addFont('regular.ttf', 'regular', 'normal');
doc.setFont('regular');

这里的”regular.ttf” 就是键名, 第二个参数可以当做别名,第三个照抄就行,最后是使用该字体.

6.最后还是觉得很麻烦啊!!!

这篇关于前端使用jsPdf导出pdf文档的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/174245

相关文章

Python将博客内容html导出为Markdown格式

《Python将博客内容html导出为Markdown格式》Python将博客内容html导出为Markdown格式,通过博客url地址抓取文章,分析并提取出文章标题和内容,将内容构建成html,再转... 目录一、为什么要搞?二、准备如何搞?三、说搞咱就搞!抓取文章提取内容构建html转存markdown

在React中引入Tailwind CSS的完整指南

《在React中引入TailwindCSS的完整指南》在现代前端开发中,使用UI库可以显著提高开发效率,TailwindCSS是一个功能类优先的CSS框架,本文将详细介绍如何在Reac... 目录前言一、Tailwind css 简介二、创建 React 项目使用 Create React App 创建项目

vue使用docxtemplater导出word

《vue使用docxtemplater导出word》docxtemplater是一种邮件合并工具,以编程方式使用并处理条件、循环,并且可以扩展以插入任何内容,下面我们来看看如何使用docxtempl... 目录docxtemplatervue使用docxtemplater导出word安装常用语法 封装导出方

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

使用Jackson进行JSON生成与解析的新手指南

《使用Jackson进行JSON生成与解析的新手指南》这篇文章主要为大家详细介绍了如何使用Jackson进行JSON生成与解析处理,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 核心依赖2. 基础用法2.1 对象转 jsON(序列化)2.2 JSON 转对象(反序列化)3.

使用Python实现快速搭建本地HTTP服务器

《使用Python实现快速搭建本地HTTP服务器》:本文主要介绍如何使用Python快速搭建本地HTTP服务器,轻松实现一键HTTP文件共享,同时结合二维码技术,让访问更简单,感兴趣的小伙伴可以了... 目录1. 概述2. 快速搭建 HTTP 文件共享服务2.1 核心思路2.2 代码实现2.3 代码解读3.

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain