autoprefixer
自动添加CSS浏览器前缀的插件,可以根据Can I Use网站的数据,自动添加适当的前缀,以兼容不同的浏览器。
cssnano
一个优化和压缩CSS代码的插件,可以删除不必要的空格、注释、重复规则等,从而减小CSS文件大小,提高页面加载速度。
postcss-html
可以将HTML文件中的样式块中的CSS代码提取出来进行处理,这样可以使CSS代码更加集中、维护更简单。
postcss-Less
可以将Less代码转换成CSS代码。Less是一种CSS预处理器,它扩展了CSS语言的功能,可以更方便地编写和维护CSS代码。
postcss-scss
可以将SCSS代码转换成CSS代码。SCSS是一种CSS预处理器,它扩展了CSS语言的功能,可以更方便地编写和维护CSS代码。使用PostCSS-SCSS插件可以在使用SCSS的同时,也可以享受PostCSS的扩展能力,通过插件来扩展其功能。
postcss-import
可以使用@import语法来引入CSS文件,并将其合并为一个文件。它可以减少HTTP请求次数,提高页面加载速度。
postcss-preset-env
可以根据所使用的浏览器版本,自动转换CSS新特性为兼容的CSS代码。它可以让开发者在编写CSS时,不必考虑兼容性问题。
postcss-nesting
可以使用类似于Sass中的嵌套规则来编写CSS,从而使CSS代码更加简洁和易读。
postcss-custom-properties
可以使用CSS变量来编写CSS,从而可以在不同的规则中共享变量值,并且可以在运行时动态修改变量值。
postcss-px-to-viewport
可以将像素单位转换为视口单位,从而可以实现响应式布局。它可以根据设备的屏幕大小,自动计算出适当的值。
postcss-apply
可以使用类似于Sass中的@mixin语法来定义CSS变量和混合器,从而可以在不同的规则中复用代码。
postcss-color-function
可以使用类似于Sass中的颜色函数,来计算颜色值,从而可以使CSS代码更加灵活和易读。
postcss-calc
可以在CSS中使用数学表达式,从而可以进行复杂的计算。它可以减少CSS代码的重复和冗余,提高代码可维护性。
一些常用的插件与作用
autoprefixer:自动添加 CSS3 前缀。
cssnano:优化和压缩 CSS。
postcss-import:通过 @import 导入 CSS 文件。
postcss-custom-properties:使用自定义属性,类似于 Sass 中的变量。
postcss-nested:允许使用嵌套规则。
postcss-mixins:类似于 Sass 中的 mixin。
postcss-css-variables:支持 CSS 变量。
postcss-preset-env:使用最新的 CSS 语法,自动添加前缀,按需加载 polyfill。
postcss-normalize:添加浏览器默认样式的规则,以消除浏览器之间的差异。
postcss-pxtorem:将像素值转换成 rem 值,使得页面更好地适配不同大小的设备。
postcss-extend:类似于 Sass 中的 @extend。
postcss-flexbugs-fixes:修复 Flexbox 布局的一些 bug。
更多的插件
PostCSS-import:使用 @import 导入外部 CSS 文件。
PostCSS-mixins:类似于 Sass 的 Mixin。
PostCSS-nested:允许使用嵌套规则。
PostCSS-simple-vars:使用自定义变量,类似于 Sass 的变量。
PostCSS-math:进行数学计算。
PostCSS-color-function:使用颜色函数。
PostCSS-calc:使用 calc 函数。
PostCSS-extend:使用类似于 Sass 的 @extend。
PostCSS-for:使用类似于 Sass 的 @for。
PostCSS-each:使用类似于 Sass 的 @each。
PostCSS-conditionals:使用类似于 Sass 的 @if 和 @else。
PostCSS-nth-child-fix:支持伪类选择器 :nth-child。
PostCSS-modules:将 CSS 类名转换成哈希值,避免类名冲突。
PostCSS-pxtorem:将像素值转换成 rem 值,使得页面更好地适配不同大小的设备。
PostCSS-zindex:自动计算 z-index 值。
PostCSS-font-magician:自动引入相应的字体文件。
PostCSS-will-change:为元素添加 will-change 属性。
PostCSS-apply:使用类似于 CSS 变量的 @apply。
PostCSS-csso:代码压缩优化。
PostCSS-discard-comments:去除注释。
PostCSS-discard-duplicates:去除重复的样式。
PostCSS-discard-empty:去除空的样式。
PostCSS-discard-overridden:去除被覆盖的样式。
PostCSS-merge-longhand:合并长手写属性。
PostCSS-merge-rules:合并相同的规则。
PostCSS-minify-font-values:压缩字体值。
PostCSS-minify-gradients:压缩渐变值。
PostCSS-minify-params:压缩参数值。
PostCSS-minify-selectors:压缩选择器。
PostCSS-normalize-charset:添加 @charset 规则。
PostCSS-normalize-display-values:标准化 display 属性值。
PostCSS-normalize-positions:标准化定位属性值。
PostCSS-normalize-repeat-style:标准化背景重复和背景平铺属性值。
PostCSS-normalize-string:标准化字符串。
PostCSS-normalize-timing-functions:标准化缓动函数。
PostCSS-normalize-unicode:标准化 Unicode 字符。
PostCSS-normalize-url:标准化 URL。
PostCSS-normalize-whitespace:标准化空白。
PostCSS-ordered-values:按字母顺序排列属性值。
PostCSS-reduce-idents:缩短标识符,如类名、id 等。
PostCSS-reduce-initial:缩短初始值。
PostCSS-reduce-transforms:合并 transform 属性。
PostCSS-unique-selectors:去除重复的选择器。
PostCSS-pseudo-class-any-link:添加 :any-link 伪类。
PostCSS-pseudo-class-first:添加 :first-match 和 :nth-match 伪类。
PostCSS-pseudo-class-focus-within:添加 :focus-within 伪类。
PostCSS-pseudo-class-last:添加 :last-match 伪类。
PostCSS-pseudo-class-matches:添加 :matches 伪类。
PostCSS-pseudo-class-not:添加 :not 伪类。
PostCSS-pseudo-class-placeholder:添加 ::placeholder 伪类。
PostCSS-pseudo-element-any-link:添加 ::any-link 伪元素。
PostCSS-pseudo-element-content-insert:添加 ::before 和 ::after 伪元素。
PostCSS-pseudo-element-custom-properties:添加 ::part 和 ::theme 伪元素。
PostCSS-pseudo-element-dir:添加 ::dir 伪元素。
PostCSS-pseudo-element-file-selector-button:添加 ::file-selector-button 伪元素。
PostCSS-pseudo-element-fullscreen:添加 ::fullscreen 伪元素。
PostCSS-pseudo-element-placeholder-shown:添加 ::placeholder-shown 伪元素。
PostCSS-pseudo-element-range-thumb:添加 ::range-thumb 伪元素。
PostCSS-pseudo-element-scrollbar:添加 ::scrollbar 伪元素。
PostCSS-pseudo-element-scrollbar-button:添加 ::scrollbar-button 伪元素。
PostCSS-pseudo-element-scrollbar-track:添加 ::scrollbar-track 伪元素。
PostCSS-pseudo-element-scrollbar-track-piece:添加 ::scrollbar-track-piece 伪元素。
PostCSS-pseudo-element-slotted:添加 ::slotted 伪元素。