通常在phantom中,您可以这样做:
phantom = require('phantom')
phantom.create(function(ph){
ph.createPage(function(page) {
page.open("http://www.google.com", function(status) {
page.render('google.pdf', function(){
console.log('Page Rendered');
ph.exit();
});
});
});
});
然而,而不是加载一个网页,我已经有一些html我想传递和渲染为PDF。
我如何能够通过它HTML
并将其转换为PDF
, PhantomJs
是正确的方法,或者ffmpeg
是更好的方法,如果是这样,我如何使用ffmpeg
?
可以设置页面的content
属性
phantom = require('phantom')
phantom.create(function(ph){
ph.createPage(function(page) {
page.content = "Some html"//Set your html here
page.render('google.pdf', function(){
console.log('Page Rendered');
ph.exit();
});
});
});
不再支持Phantom。我建议使用Chrome DevTools团队的木偶师。代码更加清晰可读:
const puppeteer = require('puppeteer');
(async () => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.setContent(`<p>Hello world!</p>);
// alternatively it can be fetched from web
// await page.goto('https://news.ycombinator.com', {waitUntil: 'networkidle2'});
await page.pdf({path: 'hn.pdf', format: 'A4'});
await browser.close();
})();