webpack使用postcss的autoprefixer插件,并在压缩css时使用了cssnano,处理不当的状况下会致使压缩css后,部分兼容前缀(好比-webkit-)被删除的问题。css
postcss的autoprefixer配置以下:html
autoprefixer({ browsers: ['> 1%', 'iOS >= 7',"ie >= 7", 'Android >= 2.4'] })
css压缩的配置以下:webpack
//压缩css代码 new OptimizeCssAssetsPlugin({ assetNameRegExp: /\.css\.*(?!.*map)/g, //注意不要写成 /\.css$/g cssProcessor: require('cssnano'), cssProcessorOptions: { discardComments: {removeAll: true }, // 避免 cssnano 从新计算 z-index safe: true }, canPrint: true })
经过查阅资料发现,若是你使用的是webpack1.x版本,UglifyJsPlugin
这个插件开启了minimize,致使css-loader也开启了压缩,而后css-loader会使用cssnano进行压缩,而cssnano会使用到autoprefixer进行无关前缀的清理。因此能够经过给css-loader添加-autoprefixer
参数来告诉css-loader关闭掉autoprefixer
这个功能,不要强制删除某些你以为不重要的前缀。ios
{test: /\.less$/, loader: 'style-loader!css-loader?minimize&-autoprefixer!postcss-loader!less-loader'},
而上述缘由已经在webpack2.x修复,webpack2的UglifyJsPlugin
插件去掉了强制开启minimize。git
然而若是你不是使用的webpack1.x,经过排查发现,在css压缩插件未使用的时候,兼容前缀正常,一旦使用了OptimizeCssAssetsPlugin来压缩css就会丢失部分的webkit前缀。github
上面有提到,cssnano会使用autoprefixer自动清除掉一些他认为不重要的前缀。而OptimizeCssAssetsPlugin中默认了是使用cssnano。因此咱们主动关闭cssnano的autoprefixer功能便可,由于咱们已经在postcss中使用了autoprefixer插件,这里无需重复使用。web
解决方法以下:浏览器
//压缩css代码 new OptimizeCssAssetsPlugin({ assetNameRegExp: /\.css\.*(?!.*map)/g, //注意不要写成 /\.css$/g cssProcessor: require('cssnano'), cssProcessorOptions: { discardComments: {removeAll: true }, // 避免 cssnano 从新计算 z-index safe: true, //cssnano经过移除注释、空白、重复规则、过期的浏览器前缀以及作出其余的优化来工做,通常能减小至少 50% 的大小 //cssnano 集成了autoprefixer的功能。会使用到autoprefixer进行无关前缀的清理。默认不兼容ios8,会去掉部分webkit前缀,好比flex //因此这里选择关闭,使用postcss的autoprefixer功能 autoprefixer: false }, canPrint: true })
再次编译发现压缩状态时也带有所有的兼容前缀,ios8的不兼容问题即也解决。less
参考:post
http://www.css88.com/archives/7317
https://github.com/ShowJoy-com/showjoy-blog/issues/31
https://www.w3cplus.com/css/taobao-2018-year.html