1.3.2 • Published 5 months ago

@minko-fe/postcss-pxtoviewport v1.3.2

Weekly downloads
-
License
MIT
Repository
-
Last release
5 months ago

postcss-pxtoviewport

中文 | English

PostCSS插件,可以从像素单位生成 viewport 单位(vw, vh, vmin, vmax)

如果你不需要以下新特性,可以使用官方库:postcss-px-to-viewport

新特性

  • 在样式文件中重写任意 postcss-pxtoviewport 支持的选项
  • 在样式文件动态禁用转化viewport
  • 兼容vite,解决了打包后样式混乱的问题

🔧 安装

pnpm install postcss @minko-fe/postcss-pxtoviewport -D

✍️ 使用

postcss.config.js

example

// postcss.config.js
import pxtoviewport from '@minko-fe/postcss-pxtoviewport'

export default {
  plugins: [
    pxtoviewport({
      viewportWidth: 375,
      selectorBlackList: ['some-class'],
      propList: ['*'],
      atRules: ['media'],
      // ...
    }),
  ],
}

options

NameTypeDefaultDescription
unitToConvertstringpx需要转化的单位,默认 px
viewportWidthnumber | ((input: Input) => number)375视图窗口宽度
unitPrecisionnumber5小数点后精度
propListstring[]['*']可以从 px 改变为 vw 的属性,参考:propList
viewportUnitstringvw转化后的单位
fontViewportUnitstringvwfont 转化后的单位
selectorBlackList(string \| RegExp)[][]忽略的选择器,保留为 px。参考:selectorBlackList
replacebooleantrue直接在 css 规则上替换值而不是添加备用
atRulesboolean | string[]false允许at-rules中转换。参考 At-rule
minPixelValuenumber0最小的 px 转化值(小于这个值的不转化)
includestring | RegExp | ((filePath: string) => boolean) | nullnull包括的文件(与 exclude 相反)。优先级比 exclude 高。规则同 exclude
excludestring | RegExp | ((filePath: string) => boolean) | null/node_modules/i忽略的文件路径。参考:exclude
disablebooleanfalse关闭插件
convertUnitOnEndConvertUnit | ConvertUnit[] | false | nullnull插件处理的最后阶段转换单位

propList

  • 值需要完全匹配
  • 使用通配符 * 来启用所有属性. Example: ['*']
  • 在一个词的开头或结尾使用 *. (['*position*'] will match background-position-y)
  • 使用 ! 不匹配一个属性. Example: ['*', '!letter-spacing']
  • 组合 !*. Example: ['*', '!font*']

selectorBlackList

  • 如果值是字符串,它会检查选择器是否包含字符串.
    • ['body'] will match .body-class
  • 如果值是正则,它会检查选择器是否与正则相匹配.
    • [/^body$/] will match body but not .body

exclude

  • 如果值是字符串,它检查文件路径是否包含字符串
    • 'exclude' will match \project\postcss-pxtoviewport\exclude\path
  • 如果值是正则,它将检查文件路径是否与正则相匹配
    • /exclude/i will match \project\postcss-pxtoviewport\exclude\path
  • 如果值是函数,你可以使用排除函数返回 true,文件将被忽略
    • 回调将传递文件路径作为一个参数,它应该返回一个 boolean
    • function (file) { return file.includes('exclude') }

✨ 关于新特性

⚙️ 在 css 中,动态设置插件选项

当前文件禁用插件

/* pxtoviewport?disable=true */
.rule {
  font-size: 15px; // 15px
}

设置 viewportWidth

/* pxtoviewport?viewportWidth=750 */
.rule {
  font-size: 30px; // 4vw
}

🌰 以上只是简单的栗子,你可以在 css 文件中设置任意 postcss-pxtoviewport 支持的选项

聪明的你,或许已经看出来了,/* pxtoviewport?disable=true */ 很像浏览器 url?😼 没错。关于规范,只需参考:query-string

例子

/* pxtoviewport?disable=false&viewportWidth=750&propList[]=*&replace=false&selectorBlackList[]=/some-class/i */

在 css 中,忽略某一行

.rule {
  /* pxtoviewport-disable-next-line */
  font-size: 15px; // 15px
}

如果你写 15PX(只要不是 px),插件也会忽略,因为 unitToConvert 默认是 px 如果你希望使用 PX 忽略并且希望最后得到的单位是 px,你可以这样

// postcss.config.js
import pxtoviewport from '@minko-fe/postcss-pxtoviewport'

export default {
  plugins: [
    pxtoviewport({
      convertUnitOnEnd: {
        sourceUnit: /[Pp][Xx]$/,
        targetUnit: 'px',
      },
    }),
  ],
}

❤️ 感谢

postcss-px-to-viewport

@tcstory/postcss-px-to-viewport

👀 相关

A CSS post-processor that converts px to rem: postcss-pxtorem

💕 支持

如果这个仓库帮了你的忙,请不吝给个 star,谢谢!😎

1.3.2

5 months ago

1.3.1

6 months ago

1.3.0

11 months ago

1.3.0-beta.1

11 months ago

1.2.2

11 months ago

1.3.0-beta.0

11 months ago

1.2.0

1 year ago

1.2.1

1 year ago

1.1.2

1 year ago

1.1.1

1 year ago

1.0.2

1 year ago

1.1.0

1 year ago

1.0.1

1 year ago

1.0.0

1 year ago

0.0.4

1 year ago

1.0.4

1 year ago

1.0.3

1 year ago

0.0.3

2 years ago

0.0.2

2 years ago

0.0.1

2 years ago