Skip to content

Convert pixel units to rem (root em) units using PostCSS

Notifications You must be signed in to change notification settings

TonyXiang/postcss-pxtorem-multi

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

57 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

postcss-pxtorem-multi NPM version

This is a fork based on postcss-pxtorem. The difference is postcss-pxtorem-multi supports multiple rules.

Install

$ npm install postcss-pxtorem-multi --save-dev

options

Type: Object | Null
Default:

{
    include: null,
    exclude: null,
    rootValue: 16,
    unitPrecision: 5,
    propList: ['font', 'font-size', 'line-height', 'letter-spacing'],
    selectorBlackList: [],
    replace: true,
    mediaQuery: false,
    minPixelValue: 0,
    rules: []
}
  • include (String|RegExp|Array<String|RegExp>) Files to include
  • exclude (String|RegExp|Array<String|RegExp>) Files to exclude
  • rootValue (Number) The root element font size.
  • unitPrecision (Number) The decimal numbers to allow the REM units to grow to.
  • propList (Array) The properties that can change from px to rem.
    • Values need to be exact matches.
    • Use wildcard * to enable all properties. Example: ['*']
    • Use * at the start or end of a word. (['*position*'] will match background-position-y)
    • Use ! to not match a property. Example: ['*', '!letter-spacing']
    • Combine the "not" prefix with the other prefixes. Example: ['*', '!font*']
  • selectorBlackList (Array) The selectors to ignore and leave as px.
    • If value is string, it checks to see if selector contains the string.
      • ['body'] will match .body-class
    • If value is regexp, it checks to see if the selector matches the regexp.
      • [/^body$/] will match body but not .body
  • replace (Boolean) replaces rules containing rems instead of adding fallbacks.
  • mediaQuery (Boolean) Allow px to be converted in media queries.
  • minPixelValue (Number) Set the minimum pixel value to replace.
  • rules: (Object) Supporting all the above parameters.

Use with gulp-postcss (Gulp)

var gulp = require('gulp');
var postcss = require('gulp-postcss');
var pxtorem = require('postcss-pxtorem-multi');

gulp.task('css', function () {

    var processors = [
        pxtorem({
            rootValue: 16,
            rules: [
                {
                    include: 'common.css',
                    rootValue: 32,
                }
            ]
        })
    ];

    return gulp.src(['build/css/**/*.css'])
        .pipe(postcss(processors))
        .pipe(gulp.dest('build/css'));
});

Use with postcss-loader (Webpack)

postcss.config.js or .postcssrc.js

module.exports = {
    plugins: {
        "postcss-pxtorem-multi": {
            rootValue: 75,
            propList: ['*'],
            rules: [
                {
                    include: ['/node_modules/vant/'],
                    rootValue: 37.5,
                    propList: ['*'],
                }
            ]
        }
    }
}

A message about ignoring properties

Currently, the easiest way to have a single property ignored is to use a capital in the pixel unit declaration.

// `px` is converted to `rem`
.convert {
    font-size: 16px; // converted to 1rem
}

// `Px` or `PX` is ignored by `postcss-pxtorem-multi` but still accepted by browsers
.ignore {
    border: 1Px solid; // ignored
    border-width: 2PX; // ignored
}

About

Convert pixel units to rem (root em) units using PostCSS

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 97.0%
  • CSS 3.0%