jsPDF生成pdf文件和中文编码
jsPDF的简单使用以及中文编码问题的解决
文中js通过CDN引入,若是为了加载时间最好下载至本地。
jsPDF的使用
- jsPDF简介
jsPDF 是一个基于 HTML5 的客户端解决方案,用于在客户端JavaScript中生成PDF的库。有着方法简单,易于实现的优点。
简单使用
因为为了页面美观,使用bootstrap进行简单设计,所以要先引入bootstrap相关的css和javascript。
css:<!-- Bootstrap CSS -->
<link rel="stylesheet" href="https://cdn.bootcss.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">javascript:
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.slim.min.js" integrity="sha384-KJ3o2DKtIkvYIK3UENzmM7KCkRr/rE9/Qpg6aAZGJwFDMVNA/GpGFF93hXpG5KkN" crossorigin="anonymous"></script>
<script src="https://cdn.bootcss.com/popper.js/1.12.9/umd/popper.min.js" integrity="sha384-ApNbgh9B+Y1QKtv3Rn7W3mgPxhU9K/ScQsAP7hUibX39j7fakFPskvXusvfa0b4Q" crossorigin="anonymous"></script>
<script src="https://cdn.bootcss.com/bootstrap/4.0.0/js/bootstrap.min.js" integrity="sha384-JZR6Spejh4U02d8jOt6vLEHfe/JQGiRRSQQxSfFWpi1MquVdAyjUar5+76PVCmYl" crossorigin="anonymous"></script>html片段:
<div class="container">
<div class="row">
<h2>导出demo</h2>
<table class="table table-striped" id="myTable">
<thead>
<tr>
<th scope="col">ID</th> <th scope="col">First</th>
<th scope="col">Last</th> <th scope="col">Handle</th>
</tr>
</thead>
<tbody>
<tr>
<th scope="row">1</th> <td>Mark</td>
<td>Otto</td> <td>@mdo</td>
</tr>
<tr>
<th scope="row">2</th> <td>Jacob</td>
<td>Thornton</td> <td>@fat</td>
</tr>
<tr>
<th scope="row">3</th> <td>Larry</td>
<td>the Bird</td> <td>@twitter</td>
</tr>
</tbody>
</table>
<button class="btn btn-primary" onclick="exportPDF()">导出表格</button>
</div>
</div>接下来引入jsPDF的相关javascript:
<!--PDF插件START-->
<script src="https://cdn.bootcss.com/jspdf/1.3.5/jspdf.min.js"></script>
<script src="https://cdn.bootcss.com/jspdf/1.3.5/jspdf.debug.js"></script>
<!--PDF插件END-->实现方式:
function exportPDF() {
var doc = new jsPDF('p', 'pt');
//pdf标题设置
doc.text(20, 20, 'hello world!'); doc.save('导出.pdf');
}导出表格
为了处理相关表格数据,根据jsPDF引入相关javascript:<script src="https://cdn.bootcss.com/jspdf-autotable/3.0.0-alpha.1/jspdf.plugin.autotable.min.js"></script>简单实现
<script type="text/javascript">
var myTable = $("#myTable");
// 获取title
var tableThs = myTable.find("thead th");
//获取每个tr
var tableTrs = myTable.find("tbody tr");
var columns = [];
//处理title数组
tableThs.each(function () {
columns.push({title: $(this).text(), key: $(this).text()});
});
//处理数据数组
var data = [];
tableTrs.each(function () {
var tds = $(this).children();
var object = {};
//生成数据对象
$.each(columns, function (i, r) {
var tdTitle = columns[i].key;
//'object'跟上文对象名称一致,动态件加属性和值
eval('object.' + tdTitle + '="' + $(tds).eq(i).text() + '"');
});
data.push(object);
}); function exportPDF() {
var doc = new jsPDF('p', 'pt');
doc.text(20, 20, 'hello world!');
doc.autoTable(columns, data, {}); doc.save('导出.pdf');
}
</script>中文处理
导出过程中发现中文显示乱码,根据文档发现jsPDF不支持中文,网上资料是使用html2canvas方式转换canva方式,并不是十分灵活。后根据项目jsPDF-CustomFonts-support引入中文字体,解决了导出pdf后中文字体显示乱码的问题。
这个插件并没有CDN,将项目源码下载到本地,dist文件夹下为相关脚本,font文件夹下为相关字体文件。<script src="../js/jspdf.customfonts.debug.js"></script>
<script src="../js/jspdf.customfonts.min.js"></script>
<script src="../js/default_vfs.js"></script>脚本实现
var doc = new jsPDF('p', 'pt');
doc.addFont('NotoSansCJKtc-Regular.ttf', 'NotoSansCJKtc', 'normal');
//pdf标题设置
doc.setFont('NotoSansCJKtc');
//pdf标题设置
doc.text(20, 20, '导出标题');
//doc.autoTable(columns, data, {});
// https://github.com/simonbengtsson/jsPDF-AutoTable 主要属性参考
doc.autoTable(columns, data, {styles: {cellPadding: 0.5, fontSize: 8, font: "NotoSansCJKtc"}}); doc.save('导出.pdf');- 最终样式
jsPDF生成pdf文件和中文编码的更多相关文章
- ThinkPHP3.2.3扩展之生成PDF文件(MPDF)
目前是PHP生成PDF文件最好的插件了,今天介绍下在ThinkPHP3.2.3里如何使用. 先安照路径放好如图. 下面是使用方法 public function pdf(){ //引入类库 Vendo ...
- 在js内生成PDF文件并下载的功能实现(不调用后端),以及生成pdf时换行的格式不被渲染,word-break:break-all
在js内生成PDF文件并下载的功能实现(不调用后端),以及生成pdf时换行的格式不被渲染,word-break:break-all 前天来了个新需求, 有一个授权书的文件要点击下载, 需要在前端生成, ...
- linux下编译bib、tex生成pdf文件
实验: 在linux环境下,编译(英文)*.bib和*.tex文件,生成pdf文件. 环境: fedora 20(uname -a : Linux localhost.localdomain 3.19 ...
- [轉載]史上最强php生成pdf文件,html转pdf文件方法
之前有个客户需要把一些html页面生成pdf文件,然后我就找一些用php把html页面围成pdf文件的类.方法是可谓是找了很多很多,什么html2pdf,pdflib,FPDF这些都试过了,但是都没有 ...
- asp.net生成PDF文件 (1)
asp.net生成PDF文件 (1) 这个是例子是网上淘来的,哈哈,很有用的! 首先要到网上下载itextsharp.dll,然后添加引用,主程序如下: 1 2 3 4 5 6 7 8 9 10 11 ...
- 怎么用PHP在HTML中生成PDF文件
原文:Generate PDF from html using PHP 译文:使用PHP在html中生成PDF 译者:dwqs 利用PHP编码生成PDF文件是一个非常耗时的工作.在早期,开发者使用PH ...
- JAVA生成PDF文件
生成PDF文件是主要应用的是ITEXT插件 import java.awt.Color; import java.io.File; import java.io.FileOutputStream; i ...
- .NET生成PDF文件
C#未借助第三方组件,自己封装通用类,生成PDF文件. 调用方式: //路径 string path = @"C:\yuannwu22.pdf"; //内容 string strC ...
- 史上最强php生成pdf文件,html转pdf文件方法
body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...
随机推荐
- mybatis N+1问题解决
关联嵌套查询 示例: <resultMap id="blogResult" type="Blog"> <association propert ...
- VMware中centos7访问外网配置
1.配置虚拟机网络适配器,选择NAT模式 2.在编辑->虚拟机网络编辑器->更改设置 选择目前使用的网卡 3.通过ifconfig查看网卡配置 4.编辑网络配置对应上面网卡名称ens33 ...
- java多线程之并发编程
1.并发不一定比串行更快 因为并发有线程创建和上下文切换的开销 2.java的并发采用内存共享模型 3.单线程中重排序不会影响到结果 但多线程中重排序可能会影响到结果 4.votaile变量 当线程A ...
- org.apache.shiro.realm.AuthorizingRealm - No cache or cacheManager properties have been set. Authorization cache cannot be obtained.
项目中用spring shiro来处理权限的问题,但是启动的时候会打印如下日志 org.apache.shiro.realm.AuthorizingRealm - No cache or cacheM ...
- Java排序--排序算法(内排序)
常用内排序算法 我们通常所说的排序算法往往指的是内部排序算法,即需要排序的数据在计算机内存中完成整个排序的过程,当数据率超大或排序较为繁琐时常借助于计算机的硬盘对大数据进行排序工作,称之为外部排序算法 ...
- GridView中点击某行的任意位置就选中该行
GridView中点击某行的任意位置就选中该行 -- :: 分类: 第一步:添加选择列 点击GridView右边小尖头,双击CommandField,选中"选择",添加,将起设置为不可见: 第二步:处 ...
- 11 Scrapy框架之递归解析和post请求
一.递归爬取解析多页页面数据 - 需求:将糗事百科所有页码的作者和段子内容数据进行爬取切持久化存储 - 需求分析:每一个页面对应一个url,则scrapy工程需要对每一个页码对应的url依次发起请求, ...
- 第三篇 HTML 表单及表格
表单及表格 表单,常用在登录.注册等地方,这也是一个最基本的. 我们就用登录,来学习什么是表单! 表单 form 标签,在某些好用的编辑工具,比如:WebStorm 你在上面写出form再按 ...
- TKmybatis和mybatisplus哪个好用
文档连接 :http://baomidou.oschina.io/mybatis-plus-doc/#/?id=%E7%AE%80%E4%BB%8B https://gitee.com/hengboy ...
- python cv2读取rtsp实时码流按时生成连续视频文件
代码实现 # coding: utf-8 import datetime import cv2 import os ip = '192.168.3.160'.replace("." ...