Skip to content

Latest commit

 

History

History
47 lines (38 loc) · 3.24 KB

README.md

File metadata and controls

47 lines (38 loc) · 3.24 KB

CSS inliner

A node.js module inlining used styles on a given page, as proposed by the Google Pagespeed team: Optimizing the Critical Rendering Path for Instant Mobile Websites - Velocity SC - 2013

How it works

The inliner works by loading the content in PhantomJS, extracting and parsing the CSS used, stripping away any CSS not being used. Stylesheets are downloaded seperately to avoid any browser-bias there might be.

It supports loading content through a URL or by passing on the HTML and a "fake" URL.

Usage

var inliner = require("css-inliner");

inliner({
  url: "http://www.dr.dk/tv"
}, function(error, html) {
  if (!error) {
    // Do whatever you want with the HTML
  }
});

Options

Option Default Description
url  null Requred: The URL to be loaded (or faked, if the HTML is specified).
html  null The HTML content to use, instead of loading the URL specified.
cssMedia  null By default it only processes stylesheets with media query all, screen, and those without one. Specify here which others to include.
cssMinify false Can be either a boolean (true) or an object with parameters to pass on to the clean-css module.
cssOnly false If true, it'll return the CSS only. No HTML.
cssId null The id-attribute to be set on the <style>-tag.
exposeVar null All the stripped stylesheets can be exposed in a JavaScript-variable, at the bottom of the <body>-tag, for you to use (i.e. loading the stylesheets when the page has finished loading).
exposeJS null Additionally to the above, you can choose to append JavaScript beneath the exposed variable. Requires exposeVar to be set.
ignoreSheets null An array of stylesheets to ignore. Can be either exact strings or regular expressions (or a mix of those).
ignoreSelectors null An array of selectors/rules to keep at all times. These will not be stripped. Can be either exact strings or regular expressions (or a mix of those).
ignoreExternalSheets false If true, all external stylesheets are ignored.
useDomino false If true, domino is used instead of PhantomJS. No JavaScript is executed this way.
log false Whether or not to print out log messages.

Contributing or contact me

Any contributions are welcome. Simply fork the repository and make a pull request describing what you added/changed/fixed.

You can contact me through Twitter or by creating an issue at my feedback repository.

In case the green men from outer space abduct me @mattsoltani have all the powers needed, too.

License

This module is released under the Apache 2.0 License.