[!IMPORTANT] Code has been moved to sonofmagic/postcss-plugins, this repo is archived!
A plugin for PostCSS that generates px or rpx units from rem units.
typescript
and well tested.px
and rpx
!If you still use
postcss@7.x
, you should usepostcss-rem-to-responsive-pixel@5.x
See version 6 breaking changes
npm i -D postcss-rem-to-responsive-pixel
yarn add -D postcss-rem-to-responsive-pixel
pnpm i -D postcss-rem-to-responsive-pixel
// postcss.config.js
module.exports = {
plugins: [
// for example
// require('autoprefixer'),
// require('tailwindcss'),
require('postcss-rem-to-responsive-pixel')({
rootValue: 32,
propList: ['*'],
transformUnit: 'rpx',
}),
],
}
When you use tailwindcss
to write your website or miniprogram, the default unit is rem
, so sometimes we have to transform our unit to px
or rpx
.
// postcss.config.js
module.exports = {
plugins: [
require('tailwindcss'),
require('postcss-rem-to-responsive-pixel')({
rootValue: 32,
propList: ['*'],
transformUnit: 'rpx',
}),
],
}
With the default settings, only font related properties are targeted.
// input
h1 {
margin: 0 0 20px;
font-size: 2rem;
line-height: 1.2;
letter-spacing: 0.0625rem;
}
// output
h1 {
margin: 0 0 20px;
font-size: 64rpx;
line-height: 1.2;
letter-spacing: 2rpx;
}
Type: Object | Null
Default:
{
rootValue: 16,
unitPrecision: 5,
selectorBlackList: [],
propList: ['font', 'font-size', 'line-height', 'letter-spacing'],
replace: true,
mediaQuery: false,
minRemValue: 0,
exclude: [/node_modules/i],
transformUnit: 'px',
disabled: false
}
Type: number
The root element font size.
Type: number
The decimal precision px units are allowed to use, floored (rounding down on half).
Type: (string | RegExp)[]
The properties that can change from rem to px.
Type: (string | RegExp)[]
The selectors to ignore and leave as rem.
Type: boolean
replaces rules containing rems instead of adding fallbacks.
Type: boolean
Allow rem to be converted in media queries.
Type: number
Set the minimum rem value to replace.
Type: (string | RegExp)[] | ((filePath: string) => boolean)
The file path to ignore and leave as px.
Type: 'px' | 'rpx'
The transform output unit.
Type: boolean
If disable this plugin.
Currently, the easiest way to have a single property ignored is to use a capital in the rem unit declaration.
// `rem` is converted to `px`
.convert {
font-size: 1rem; // converted to 16px
}
// `Rem` or `REM` is ignored by `postcss-rem-to-pixel` but still accepted by browsers
.ignore {
border: 1rem solid; // ignored
border-width: 2rem; // ignored
}
Thanks to the author of postcss-rem-to-pixel
and postcss-pxtorem
.