jsPDF2.5版本 默认不支持utf-8的字体 具体看官方的说明,默认是不支持中文的。要使用中文需要自己添加字体。

1 将字体转换为base64编码 然后引入。也可以直接引入二进制文件,但没试过这个。

建议直接使用jsPFD源码里的 /fontconverter/fontconverter.html

直接选择文件 点create

会生成一个导入字体的 js脚本 如果不是用的 module 方式引入js的 需要稍作修改。

注意事项

1字体文件不要太庞大 例如15M以上。太大会导致内存溢出错误。

2选的字体一定要包含你要用的字 否则就会显示空白 或者乱码。

比如 你页面上 有个字:中,在你的字体文件里面没有这个字形,那就会导致 出现中的地方都是空白或乱码。

3并不是所有的字体都能正常工作,这里我使用了方正黑体 和 NotoSansCJKtc-Regular

2 页面上引入这个字体,并将该字体设置为默认字体

如果你是用jsPDF.html()方法生成pdf的 这一步很重要

3 在要使用字体之前 设置字体

点击查看代码
var pdf = new jsPDF('l', 'pt');
pdf.setFont("fzht"); // set font
pdf.text(10, 10, '欢迎访问 hangge.com');

具体代码如下:

<!DOCTYPE html>
<html>
<head>
    <title>Html2Pdf</title>
    <meta charset="utf-8">
    <link rel="stylesheet" type="text/css" href="examples.css">
    <style>
        @font-face {
            font-family: 'fzht';
            font-display: swap;
            src: url('./fonts/fzht.ttf') format('truetype')
        }
        body,
        button,
        #html {
            font-family: fzht;
        }
        table td {
            border: 1px solid silver;
            padding: 3px;
        }
    </style>
</head>
<body>
    <div id="html">
        <i>你好nihao</i>
        <ul>
            <li>一</li>
            <li>二</li>
            <li>三</li>
            <li>四</li>
        </ul>
        <h1>Tables</h1>
        <table class='table2'>
            <tr>
                <td>项目</td>
                <td>花费</td>
                <td>说明</td>
                <td>Available</td>
            </tr>
            <tr>
                <td>牛奶</td>
                <td>$1.00</td>
                <td>Hello PDF World你好PDF</td>
                <td>Out Of Stock</td>
            </tr>
            <tr>
                <td>Milk</td>
                <td>$1.00</td>
                <td>Hello PDF World</td>
                <td>Out Of Stock</td>
            </tr>
        </table>
        <button onclick="printPDF();" type="button">打印</button>
    </div>
    <script src="https://html2canvas.hertzen.com/dist/html2canvas.js"></script>
    <script src='../../dist/jspdf.umd.js'></script>
    <script src='./fonts/fzht-normal.js'></script>
    <script>
        //fzht-normal.js
        (function () {
            return
            let { jsPDF } = jspdf;
            var callAddFont = function () {
                var font = '一长串base64编码'
                this.addFileToVFS('fzht-normal.ttf', font);
                this.addFont('fzht-normal.ttf', 'fzht', 'normal');
            };
            jsPDF.API.events.push(['addFonts', callAddFont])
        })();
    </script>
    <script>
        var canPrint = false;
        const { jsPDF } = jspdf
          var pdf = new jsPDF({
            orientation: "l",//l 横向 p 纵向
            unit: "px",//这个单位设置了也没啥左右 好像一直都是用的px
            hotfixes: ["px_scaling"],
            format: [925.44, 357.5],// 纸张大小 默认a4 可选a0-a10 或者数组[宽,高] 单位好像一直是px
            putOnlyUsedFonts: true,
        });
//通过pageCount 指定要打印几页
        function printPDF(onlyFirstPage=true,pageCount=1) {
pdf.setFont("fzht"); // set font html页面上也要设置字体 否则无效
//html转pdf 还是先把html转图片 再转pdf
//超出pdf页面大小的部分 将不会显示
//打印预览页面调整横向 纵向 会自动缩放
pdf.html(printElement, {
callback: function (pdf1) {
//成功回调
//如果要添加中文 需要重新设置字体
//pdf.setFont("fzht"); // set font
//pdf1.text(10, 10, '欢迎访问 hangge.com');
//保证只留第一页
var pCount = pdf1.getNumberOfPages()
if(pageCount<1)pageCount=1; //打印指定页数 超过的删除
while(pCount>pageCount){
for (var i = pageCount+1; i <= pCount; i++) {
console.log(i)
pdf1.deletePage(i)
}
pCount = pdf1.getNumberOfPages()
} pdf1.autoPrint();// 直接打印 不显示预览页 好像没用 还是有预览页面
//pdf1.autoPrint();//当在页面中打开pdf时候 直接打印 没有被打开过就不会弹出打印
var iframe = document.getElementById('printframe');
iframe.src = pdf1.output('bloburl');
}
});
}
    </script>
</body>
</html>

自动分页打印

<style>
#html {
height: auto;
font-family: fzht;
width: 241mm;
background-color: #fff;
overflow: hidden;
}
.print-page {
height: 92mm;
width: 241mm;
overflow: hidden;
}
</style> <div id="html">
@{
//每页的内容条数固定 //这样能算出来指定的内容需要打印几页
//打印完毕后 移除多余的页面 就可以保证没有空白页
var startIndex = 0;
var page= 0;
while (startIndex < Model.ApplyItem.Count)
{
var items = Model.ApplyItem.Skip(startIndex).Take(6);
startIndex += 6;
page++;
<div class="print-page"> <table class="tborder"> @foreach (var item in items)
{
<tr>
<td>@item.StoreHouseName</td>
<td>@item.Memo</td>
</tr>
}
</table>
</div>
}
}
</div>
@section js{
<script>
printPDF(false,@(page));
</script>
}

jsPDF 添加 中文字体 分页打印 移除空白页的更多相关文章

  1. 织梦dede编辑器ckeditor如何添加中文字体不乱码

    dedecms内容编辑器ckeditor没有中文字体,找了很多教程都是千篇一律,而且都是错的,终于找到了一篇,结合自己的实际操作,来教您如何添加中文字体,并且解决乱码问题.   工具/原料 dedec ...

  2. Cent os 6.8添加中文字体

    作者:邓聪聪 Cent os 6.8添加中文字体的相关步骤: [root@bogon ]#yum -y install fontconfig #yum安装fontconfig [root@bogon ...

  3. FCKEditor编辑器添加中文字体的方法

    默认情况下,FCKEditor在进行文本编辑时,无法使用中文字体.让其添加中文字体的方法: 1.打开 fckconfig.js 文件,找到第154行(大概),会发现: 程序代码: FCKConfig. ...

  4. CENTOS 7 和 JDK 添加中文字体

    写在前面的话 当运维总是遇到各种奇奇怪怪的问题,比如新的 JAVA 项目上线,login 界面有个验证码,结果部署后发现,要么显示的奇奇怪怪,要么压根不显示. 或者在使用一些开源的 JAVA 项目的时 ...

  5. Linux 添加中文字体库,解决Java 生成中文水印不显示问题

    本机 Windows 环境测试以下代码生成中文水印完全没问题,但是发布到Linux下不显示,一开始以为是报错了没打印出来,搜索发现直接提示中文乱码的或者不显示的,才明白原来是字体库原因,于是开始解决这 ...

  6. Ubuntu 添加中文字体

    查看系统类型 cat /proc/version 查看中文字体 fc-list :lang=zh-cn 安装字体 sudo apt install -y --force-yes --no-instal ...

  7. excel打印出现多余空白页

    问题: 解决方法一:设置打印区域 步骤:选择需要打印的内容--页面布局--打印区域--设置打印区域即可 解决方法二:删除多余的打印空白页 步骤:视图--分页预览--选中多余的空白页删除即可

  8. chrome浏览器使用jqprint插件打印时偶尔空白页问题

    最近测试老是提bug说是有50%的概率打印出空白页,之前我也一直发现偶尔会出现这个问题,只是一直没有发现原因. 今天终于下定决心找到问题所在.开始吧! 查看源码一行行debug,发现问题只可能出现在这 ...

  9. 制作OpenOffice的Docker镜像并添加中文字体解决乱码问题

    官网下载openoffice http://www.openoffice.org/download/index.html 本文使用的是Docker官方发布的CentOS7镜像作为基础镜像.镜像的获取方 ...

  10. CentOS 7 安装字体库 & 中文字体

    前言 报表中发现有中文乱码和中文字体不整齐(重叠)的情况,首先考虑的就是操作系统是否有中文字体,在CentOS 7中发现输入命令查看字体列表是提示命令无效:  如上图可以看出,不仅没有中文字体,连字体 ...

随机推荐

  1. DataGear 制作自定义柱状图条目颜色的数据可视化看板

    DataGear 看板提供了dg-chart-options图表选项配置功能,可自定义样式.位置.显示内容等图表选项,其中的processUpdateOptions回调函数配置项,可以在图表更新数据前 ...

  2. rt_snprintf()是什么

    在c++中snprintf()函数的解释 1,函数原型: int snprintf(char* dest_str,size_t size,const char* format,...); 2,功能 将 ...

  3. Python列表转换成字典、嵌套列表转字典、多个列表转为字典嵌套列表

    目录 两列表转为字典 多列表转为字典嵌套列表 嵌套列表转字典 方法一:直接内置dict 方法二: for循环 一个列表转字典 两列表转为字典 list1=["key1"," ...

  4. cglib FastClass机制

    前言 关于动态代理的一些知识,以及cglib与jdk动态代理的区别,在这一篇已经介绍过,不熟悉的可以先看下. 本篇我们来学习一下cglib的FastClass机制,这是cglib与jdk动态代理的一个 ...

  5. Springboot K8s Job 一次性任务 如何禁用端口监听

    问题:SpringBoot一次性任务执行时,也会默认监听服务端口,当使用k8s job运行时,可能多个pod执行存在端口冲突 解决办法:命令行禁用SpringBoot一次性任务启动时端口占用 java ...

  6. WPF之命令

    目录 命令系统的基本元素 基本元素之间的关系 小试命令 WPF的命令库 命令参数 命令与Binding的结合 近观命令 ICommand接口与RoutedCommand 自定义Command 定义命令 ...

  7. github无法访问?vscode 无法使用github登录同步? 改 hosts 吧

    一.无法访问 github.com ? 想要去 github.com 上拿来主义,结果访问不了,或者 npm 时一直失败? 是什么原因不用问,直接使用 https://tool.lu/ip/  查询到 ...

  8. 逆向通达信Level-2 续十 (trace脱壳)

    本篇演示两图 1. trace 脱壳,你看到了几成指令是混淆的. 2. trace 脱壳过程中帮助 ida 定位脱壳代码片段. ida 不能定位的代码片段,通过trace来发现. 逆向通达信Level ...

  9. Android热点SoftAP使用方式

    一.背景 最近项目中Android设备需要获取SoftAP信息(wifi账号.密码.IP等),然后传递到投屏器中,那么如何获取到SoftAP信息呢?我们知道可以通过WifiManager类里的方法可以 ...

  10. CentOS 同时安装多个版本的Python3

    1.背景 已安装了 Python3.6.4,需要再安装 Python3.9 版本 2.操作步骤 (1)寻找当前 Python3.9 版本最新稳定版的子版本 通过官网查找,目前为 3.9.18,下载到本 ...