解决Angular Kendo UI 导出PDF中文乱码

本文介绍如何解决KendoUI for Angular的PDFExportComponent组件在导出包含中文内容时出现乱码的问题。通过替换默认字体为Microsoft YaHei,并使用@font-face指定或defineFont方法设置字体路径,实现PDF中文正常显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用 Kendo UI for AngularPDFExportComponent 组件时,如果内容是中文则导出PDF将会出现乱码,网上许多人认为是官方不支持中文,但其实不然,阅读文档

The PDF Export component supports the Unicode standard only if the fonts you provide contain glyphs for the referenced Unicode characters

发现导致乱码的问题是该组件只支持Unicode标准的字体,官方默认字体是 DejaVu Sans,这字体一看就不是好东西,胆敢不支持我大天朝的语言。找到乱码的原因了,那接下来就是换了这个字体,官方提供了两种方式:

  • @font-face 指定

Microsoft Yahei 字体下载,下载完成后将.ttf文件存放在项目下,然后在@font-face 下的 src 指定到该文件,如下

@font-face {
  font-family: 'DejaVu Sans';
  src: url('../../Microsoft Yahei.ttf') format('truetype');
}
  • defineFont 方法(推荐)

同样下载 Microsoft Yahei 字体,设置如下:

import { defineFont } from '@progress/kendo-drawing/pdf';

...

@ViewChild('pdf') pdf: PDFExportComponent;

public print(): void {
    ...
    defineFont({
        'Microsoft Yahei': '../../Microsoft Yahei.ttf'
    });//也可以在 ngInit() 中设置

    this.pdf.saveAs('example.pdf');
}

OK,可以愉快的导出中文了~

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值