js 生成中文 PDF 有啥好办法? - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a Javascript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
Javascript 权威指南第 5 版
Closure: The Definitive Guide
jatsz2020
V2EX    Javascript

js 生成中文 PDF 有啥好办法?

  •  
  •   jatsz2020 2021-10-24 12:06:49 +08:00 4528 次点击
    这是一个创建于 1449 天前的主题,其中的信息可能已经有所发展或是发生改变。
    html2pdf 支持中文,html 排版,但是生成的 PDF 是图片的,无法复制里面的文字

    jspdf 搞了好久无法支持中文,然后前端加载一个几十兆的字体也麻烦
    15 条回复    2021-10-26 11:00:33 +08:00
    codehz
        1
    codehz  
       2021-10-24 12:16:12 +08:00 via Android
    要支持矢量化中文就必须得自己提供字体。。。浏览器的 api 只能糊成像素的(
    binux
        2
    binux  
       2021-10-24 12:19:56 +08:00 via Android
    @codehz 理论上讲完全可以,文字是图片的,但是可以复制。
    MonikaCeng
        3
    MonikaCeng  
       2021-10-24 13:16:25 +08:00 via Android
    我之前用 windows 服务器,用了一个.exe 文件,php 命令行调用它去将网页转 pdf ,中文,文本可复制,链接可点击。linux 应该这种插件更多
    beyondstars
        4
    beyondstars  
       2021-10-24 13:58:33 +08:00
    建议让后端用 TeX (LaTeX, XeLaTeX) 实现文本到 PDF 的渲染,然后后端通过 API 的形式把功能开放给前端,这样前端可以通过 JS 发起异步请求调接口实现这个功能,生成的 PDF 质量也有保证。
    jaywhen
        5
    jaywhen  
       2021-10-24 14:41:43 +08:00   1
    Typora 用的 [pdf-lib]( https://github.com/Hopding/pdf-lib/ ),但是默认不支持渲染中文,如一楼所说得自己提供字体,嫌中文字体文件大可以用 [gulp-fontmin]( https://github.com/ecomfe/gulp-fontmin) 对字体文件压缩一下
    jaywhen
        6
    jaywhen  
       2021-10-24 14:45:51 +08:00
    @jaywhen 链接格式有点乱抱歉
    muzuiget
        7
    muzuiget  
       2021-10-24 17:00:10 +08:00   2
    PDF 太复杂了,还不如弄个打印布局页面,让用户通过打印功能生成。
    codehz
        8
    codehz  
       2021-10-24 21:08:30 +08:00 via Android
    @muzuiget (这么说直接用 window.print()方法就可以了,大道至简
    zeni123
        9
    zeni123  
       2021-10-24 21:20:10 +08:00
    后端使用 headless chrome 打印, 多复杂的都能打印出来
    qiaobeier
        10
    qiaobeier  
       2021-10-24 21:28:35 +08:00
    前端嵌入字体文件涉及安全问题(浏览器沙盒),还是用后端吧,一大堆解决方案。
    ccraohng
        11
    ccraohng  
       2021-10-25 07:58:51 +08:00
    后端吧,node 用 puppeteer, wkhtmltopdf 也可以
    deadofpeople
        12
    deadofpeople  
       2021-10-25 10:38:24 +08:00
    wkhtmltopdf
    nicknick
        13
    nicknick  
       2021-10-25 10:49:31 +08:00 via Android
    别别,你让后端做吧。某日客户拿个 ie9 跟你呛下载不了你就知道了。
    supuwoerc
        14
    supuwoerc  
       2021-10-25 14:19:29 +08:00
    jspdf 有个韩国人做过支持多语言的二次开发,很久之前我记得有小伙伴用过,可以在 github 上找一找。
    Kasumi20
        15
    Kasumi20  
       2021-10-26 11:00:33 +08:00
    强烈推荐 React-PDF ,不过中文需要自定义字体
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1052 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 27ms UTC 18:01 PVG 02:01 LAX 11:01 JFK 14:01
    Do have faith in what you're doing.
    ubao snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86