Pre-render single page application states and save as static HTML pages.
$ npm install headless-spa-prerender --save-dev
prerender(...pages: Array<string>, destination: string, options?: Object)
pages
<Array> - list of URLs to parse.destination
<string> - output directory.options
<Object> - optional.- pendingScripts <Array> - list of script names to load before parsing. You can also specify a part of the names (e.g. "bundle" for "bundle-1.js", "bundle-2.js", etc.).
- clearTags <Array|false> - list of tags to remove before saving. Default:
['scripts']
. - renderTimeout <int> - timeout for render page DOM before parsing. Default: 1000ms.
const prerender = require('headless-spa-prerender');
const host = 'https://promonavigator.co.id';
const pageUrls = [
`${host}/about`,
`${host}/contacts`,
`${host}/faq`,
`${host}/index`,
`${host}/prices`,
`${host}/ref-land`,
];
prerender(pageUrls, './prerendered', {
pendingScripts: ['core.js', 'front-office-2.js'],
clearTags: ['script', 'iframe'],
renderTimeout: 2000
});