url <string> StyleSheet URL text <string> StyleSheet content ranges <Array<Object>> StyleSheet ranges that were used. Ranges are sorted and non-overlapping. start <number> A startoffsetintext, inclusive end <number> An endoffsetintext, exclusive
//Stop collection and retrieve the coverage iterator const [cssCoverage] = awaitPromise.all([ page.coverage.stopCSSCoverage(), ]);
//Investigate CSS Coverage and Extract Used CSS const css_coverage = [...cssCoverage]; let css_used_bytes = 0; let css_total_bytes = 0; let covered_css = "";
for (const entry of css_coverage) { css_total_bytes += entry.text.length; console.log(`Total Bytes for ${entry.url}: ${entry.text.length}`); for (const range of entry.ranges){ css_used_bytes += range.end - range.start - 1; covered_css += entry.text.slice(range.start, range.end) + "\n"; } }
console.log(`Total Bytes of CSS: ${css_total_bytes}`); console.log(`Used Bytes of CSS: ${css_used_bytes}`); fs.writeFile("./exported_css.css", covered_css, function(err) { if(err) { returnconsole.log(err); } console.log("The file was saved!"); });