phantomjs導出html到pdf的方法總結
最近要為我們的文章服務做一個轉pdf的功能。經(jīng)過比較,我覺得phantomjs是轉化比較好的?,F(xiàn)在講講如何使用。
環(huán)境
centos x86_64
下載
可以到官網(wǎng)下載: 官網(wǎng)
或者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/ 現(xiàn)在可以在終端執(zhí)行phantomjs --version查看是否安裝成功
配置
現(xiàn)在還不夠,光phantomjs用來轉化,會存在一些問題:
- 中文亂碼
- 字體粗細不一致
解決方式:
1:中文亂碼
yum -y install bitmap-fonts bitmap-fonts-cjk
2:字體粗細不一致
這是centos不存在字體的原因,可以導入字體。
- 安裝字體管理工具: yum install -y fontconfig mkfontscale
- 訪問 c:\windows\fonts,把需要的字體copy出來。然后上傳到服務器上的 /usr/share/fonts下
- 執(zhí)行 mkfontscale, mkfontdir, fc-cache -fv三個命令,然后重啟服務器(Reboot)即可。
代碼使用
現(xiàn)在開始,就可以寫代碼了:
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,現(xiàn)在可以部署代碼試一下了。
總結
以上所述是小編給大家介紹的phantomjs導出html到pdf的方法總結,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關文章
javascript 中的console.log和彈出窗口alert
這篇文章主要介紹了javascript 中的console.log和彈出窗口alert 的相關資料,非常不錯,具有參考借鑒價值,感興趣的朋友參考下吧2016-08-08JavaScript隊列的應用實例詳解【經(jīng)典數(shù)據(jù)結構】
這篇文章主要介紹了JavaScript隊列的應用,簡單講述了隊列的概念并結合實例形式分析了基于javascript隊列排隊問題解決方法,需要的朋友可以參考下2017-04-04Bootstrap基本插件學習筆記之Popover提示框(19)
這篇文章主要為大家詳細介紹了Bootstrap基本插件學習筆記之Popover提示框的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12JS效率個人經(jīng)驗談(8-15更新),加入range技巧
JS效率個人經(jīng)驗談(8-15更新),加入range技巧...2007-01-01