Skip to content

CSS 任意单位之间的互相转换的 PostCSS 插件

Notifications You must be signed in to change notification settings

noyobo/postcss-units-transform

Repository files navigation

postcss-units-transform

Build Status npm version change-log codecov

CSS 任意单位之间的互相转换的 PostCSS插件。

Install

$ npm install postcss-units-transform --save-dev

Usage

Input/Output

如果使用 默认的 opts,将会得到如下的输出。

/* input */
p {
  margin: 0 0 20px;
  font-size: 32px;
  line-height: 1.2;
  letter-spacing: 1px; /* no */
}

/* output */
p {
  margin: 0 0 20rpx;
  font-size: 32rpx;
  line-height: 1.2;
  letter-spacing: 1px;
}

Example

var fs = require('fs');
var postcss = require('postcss');
var pxtorem = require('postcss-pxtorem');
var css = fs.readFileSync('main.css', 'utf8');
var options = {
  replace: false,
};
var processedCss = postcss(pxtorem(options)).process(css).css;

fs.writeFile('main-rem.css', processedCss, function (err) {
  if (err) {
    throw err;
  }
  console.log('Rem file written.');
});

options

Type: Object | Null

Default:

{
  divisor: 1,
  multiple: 1,
  decimalPlaces: 2,
  comment: 'no',
  targetUnits: 'rpx',
  sourceUnits: 'px',
  declMembers: '*'
}

Detail:

  • divisor(Number): 除数,转换后的值 等于 pixel / divisor
  • multiple(Number): 倍数,转换后的值 等于 pixel * multiple
  • decimalPlaces(Number): 小数点后保留的位数,例如, width: 100px 中的 100,将会被转换成 Number(100 / divisor * multiple).toFixed(decimalPlaces)
  • comment(String): 不转换 px 单位的注释,默认为 /*no*/。如果设置 comment 的值为 'not replace', width: 100px; /* not replace */ 中的 100px 将不会被转换为 rpx。
  • sourceUnits(String): 需要转换的单位,默认值为 px
  • targetUnits(String): 转换单位,默认值为 rpx,如果设置其值为 rem,px 将会被转换为 rem。
  • declMembers(String[]): 可转换的属性成员名单。

高级用法

1. 通过全局注释开启转换

优先级高于 options.declMembers 互斥关系

/* units-transform */

/* units-transform */
.main {
  height: 1rem;
  width: 2rem;
  font-size: 0.28rem;
}

2. 通过全局注释指定属性开启转换

优先级高于 options.declMembers 互斥关系

/* units-transform:height,width */

/* units-transform:height,width */
.main {
  height: 1rem;
  width: 2rem;
  font-size: 0.28rem;
}

3. 行内注释开启转换

options.declMembers 并集的关系

.main {
  height: 1rem;
  width: 2rem; /* units-transform */
  font-size: 0.36rem;
}

About

CSS 任意单位之间的互相转换的 PostCSS 插件

Resources

Stars

Watchers

Forks

Packages

No packages published