使用SASS' map-get
时,我收到以下错误。
ERROR in ./src/special.scss
Module build failed: ModuleBuildError: Module build failed: Unknown word (11:14)
9 |
10 | @mixin mediaquery($name) {
> 11 | @media #{map-get($breakpoints, $name)} {
| ^
12 | @content;
13 | }
14 | }
只有当我同时使用sass-loader
和另一个加载器时才会发生这种情况。
我first thought这是由PostCSS Loader引起的,但似乎是sass-loading导致问题而且在使用css-modules
时没有转换scss。
我已经创建了一个说明问题的示例回购:https://github.com/tiemevanveen/sass-css-components-fail-example。
您可以使用不同的分支进行测试:
master
:CSS模块+ SASS postcss
CSS模块+ SASS + PostCSS log-source
:使用CSS模块+ SASS + Custom source logging module no-css-modules
:SASS + Custom source logging module 只有第一个和最后一个分支运行且没有错误。
我已经创建了日志源示例,以查看sass-loader返回的内容和it looks like it's not transforming the sass(但这也可能是我误解了加载器的工作方式)。
没有css模块的另一个例子是show the right transformed代码..
我很困惑为什么主分支(没有postcss或其他自定义加载器)工作正常但是如果sass-loader会出现问题,那么那个也应该失败吧?
我已经提交了an issue,但我认为这有更多的机会在StackOverflow上,因为它是一个特定的问题,可能更多的是配置问题。这是我的webpack配置:
const webpack = require('webpack');
const path = require('path');
const autoprefixer = require('autoprefixer');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const WriteFilePlugin = require('write-file-webpack-plugin');
module.exports = {
devtool: 'source-source-map',
debug: true,
context: path.resolve(__dirname, './src'),
entry: {
app: './index.js'
},
output: {
path: path.resolve(__dirname, './static'),
filename: '[name].js',
publicPath: '/static/'
},
devServer: {
outputPath: path.resolve(__dirname, './static'),
},
plugins: [
new webpack.NoErrorsPlugin(),
new ExtractTextPlugin('[name].css'),
new WriteFilePlugin()
],
module: {
loaders: [
{
test: /\.scss$/,
loader: ExtractTextPlugin.extract('style-loader', [
'css?modules&importLoaders=1&localIdentName=[path]_[name]_[local]',
// 'postcss-loader',
'sass'
])
},
// + js loader
]
},
postcss: [
autoprefixer({ browsers: ['> 0.5%'] })
],
resolveLoader: {
fallback: [
path.resolve(__dirname, 'loaders'),
path.join(process.cwd(), 'node_modules')
]
},
resolve: {
extensions: ['', '.js', '.json'],
}
};
答案 0 :(得分:5)
添加加载器时,需要增加importLoaders
查询参数。该功能记录不清,令人困惑,但在您的样本回购中,importLoaders=2
同时使用Sass和PostCSS。