Is it possible to open local html file with headless chrome using puppeteer (without web server)? I could only gate it to work against local server.
I could see setContent() api and goto() api and
- page.goto: did not work with local file or file:// too.
- page.setContent: is for html string
I just did a test locally (you can see I did this on windows) and puppeteer happily opened my local html file using page.goto and a full file url, and saved it as a pdf:
'use strict';
const puppeteer = require('puppeteer');
(async() => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
await page.goto('file://C:/Users/compoundeye/test.html');
await page.pdf({
path: 'test.pdf',
format: 'A4',
margin: {
top: "20px",
left: "20px",
right: "20px",
bottom: "20px"
}
});
await browser.close();
})();
If you need to use a relative path might want to look at this question about the use of relative file paths: File Uri Scheme and Relative Files
If file is on local, using setContent will be better than goto
var contentHtml = fs.readFileSync('file://C:/Users/compoundeye/test.html', 'utf8');
await page. setContent(contentHtml);
You can check performance between setContent and goto at here
Why not open the HTML file read the content, then "setContent"
I open the file I wanted to load into the browser and copied the URL to make sure all the \'s where correct.
await page.goto(`file:///C:/pup_scrapper/testpage/TM.html`);
来源:https://stackoverflow.com/questions/47587352/opening-local-html-file-using-puppeteer