混合宏和浏览器前缀

最后更新于:2022-04-01 10:47:55

通过使用自定义混合宏来处理 CSS 中未被支持或部分支持的浏览器前缀,是非常有吸引力的一种做法。但我们不希望这么做。首先,如果你可以使用[Autoprefixer](https://github.com/postcss/autoprefixer),那就使用它。它会从你的项目中移除Sass代码,会一直更新并一定会进行比你手动添加前缀更棒的处理。 不行的是,Autoprefixer 并不是总被支持的。如果你使用 [Bourbon](http://bourbon.io/) 或[Compass](http://compass-style.org/),你可能就已经知道它们都提供了一个混合宏的集合,用来为你处理浏览器前缀,那就用它们吧。 如果你不能使用 Autoprefixe,甚至也不能使用 Bourbon 和 Compass,那么接下来唯一的方式,就是使用自己的混合宏处理带有前缀的 CSS 属性。但是,请不要为每个属性建立混合宏,更不要无脑输出每个浏览器的前缀(有些根本就不存在)。 ~~~ // Nope @mixin transform($value) { -webkit-transform: $value; -moz-transform: $value; transform: $value; } ~~~ 比较好的做法是 ~~~ /// Mixin helper to output vendor prefixes /// @access public /// @author HugoGiraudel /// @param {String} $property - Unprefixed CSS property /// @param {*} $value - Raw CSS value /// @param {List} $prefixes - List of prefixes to output @mixin prefix($property, $value, $prefixes: ()) { @each $prefix in $prefixes { -#{$prefix}-#{$property}: $value; } #{$property}: $value; } ~~~ 然后就可以非常简单地使用混合宏了: ~~~ .foo { @include prefix(transform, rotate(90deg), ('webkit', 'ms')); } ~~~ 请记住,这是一个糟糕的解决方案。例如,他不能处理那些需要复杂的前缀,比如 `flexbox`。在这个意义上说,使用 Autoprefixer 是一个更好地选择。 ## 扩展阅读 * [Autoprefixer](https://github.com/postcss/autoprefixer) * [Building a Linear-Gradient Mixin](http://www.sitepoint.com/building-linear-gradient-mixin-sass/)
';