phantomjs导出html到pdf的方法总结
2019/6/27 20:36:39
本文主要是介绍phantomjs导出html到pdf的方法总结,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
最近要为我们的文章服务做一个转pdf的功能。经过比较,我觉得phantomjs是转化比较好的。现在讲讲如何使用。
环境
centos x86_64
下载
可以到官网下载: 官网
或者wget也可以:
wget -P /tmp/ https://bitbucket.org/ariya/phantomjs/downloads/phantomjs-2.1.1-linux-x86_64.tar.bz2
安装
// 解压 tar xjf /tmp/phantomjs-2.1.1-linux-x86_64.tar.bz2 -C /usr/local/ // 重命名 mv /usr/local/phantomjs-2.1.1-linux-x86_64 /usr/local/phantomjs // 建立软连接 ln -s /usr/local/phantomjs/bin/phantomjs /usr/local/bin/ 现在可以在终端执行phantomjs --version查看是否安装成功
配置
现在还不够,光phantomjs用来转化,会存在一些问题:
- 中文乱码
- 字体粗细不一致
解决方式:
1:中文乱码
yum -y install bitmap-fonts bitmap-fonts-cjk
2:字体粗细不一致
这是centos不存在字体的原因,可以导入字体。
- 安装字体管理工具: yum install -y fontconfig mkfontscale
- 访问 c:\windows\fonts,把需要的字体copy出来。然后上传到服务器上的 /usr/share/fonts下
- 执行 mkfontscale, mkfontdir, fc-cache -fv三个命令,然后重启服务器(Reboot)即可。
代码使用
现在开始,就可以写代码了:
import phantom from 'phantom'; const pageToPdf = (url) => { phantom.create().then((ph) { ph.createPage().then((page) => { page.open(url).then((status) => { // 配置存储的pdf地址 page.render('存储的地址.pdf').then((status) => { console.log('Page rendered'); ph.exit(); }); }); }); }); }; pageToPdf('https://www.tongbanjie.com');
结果
ok,现在可以部署代码试一下了。
总结
以上所述是小编给大家介绍的phantomjs导出html到pdf的方法总结,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对找一找教程网网站的支持!
这篇关于phantomjs导出html到pdf的方法总结的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-09vue3开发前端表单缓存自定义指令,移动端h5必备插件
- 2024-05-09React Hooks在class组件中的使用方式
- 2024-03-30[OIDC in Action] 2. 基于OIDC(OpenID Connect)的SSO(纯JS客户端)
- 2024-03-29terraform jsonencode
- 2024-03-13vuex-persist
- 2024-03-11icons for vue
- 2024-03-07breadcrumbs react js
- 2024-03-06react login page example
- 2024-03-06react router uselocation
- 2024-03-04postgres jsonb_set