将HTML传递给phantom并将其呈现为PDF



通常在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();
})();

最新更新