我尝试使用一系列加载器将所有SCSS文件解压缩到一个ExtractTextPlugin
的文件中。在我拥有的一系列加载器中,我使用autoprefixer
中使用的postcss-loader
插件。但是,似乎没有任何前缀!
我的webpack配置如下:
webpack.config.js
const path = require('path');
const autoprefixer = require('autoprefixer');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const config = {
context: __dirname,
entry: {
app: [
path.resolve(entrypath),
],
},
module: {
rules: [
{
test: /\.scss$/,
use: ExtractTextPlugin.extract({
fallback: 'style-loader',
use: [
'css-loader',
'sass-loader',
{
loader: 'postcss-loader',
options: {
plugins: () => [autoprefixer()]
}
}
]
}),
},
],
},
output: {
path: path.join(__dirname, '../app/assets/javascripts/generated/'),
},
plugins: [
new ExtractTextPlugin({
filename: 'compiled-draft-document-scss.css',
allChunks: true
}),
],
};
module.exports = config;
我的输出似乎都很好,但没有添加任何前缀。以下是我正在使用的相关软件包版本:
"extract-text-webpack-plugin": "3.0.1",
"webpack": "^3.1.0",
"style-loader": "^0.19.0",
"css-loader": "^0.23.1",
"moment": "^2.11.1",
"postcss-loader": "^0.10.1",
"sass-loader": "^6.0.6",
答案 0 :(得分:16)
来自postcss-loader
README:
在
css-loader
和style-loader
之后使用,但之前 其他预处理程序加载程序,例如sass|less|stylus-loader
。
所以你的加载链应该是:
[
'css-loader',
{
loader: 'postcss-loader',
options: {
plugins: () => [autoprefixer()]
}
},
'sass-loader'
]
答案 1 :(得分:2)
在package.json文件中,添加
"browserslist": [
"> 1%",
"last 2 versions"
]