将sass-loader与css-modules

时间:2016-10-10 10:18:25

标签: sass webpack css-modules

使用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

您可以使用不同的分支进行测试:

只有第一个和最后一个分支运行且没有错误。

我已经创建了日志源示例,以查看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'],
  }
};

1 个答案:

答案 0 :(得分:5)

添加加载器时,需要增加importLoaders查询参数。该功能记录不清,令人困惑,但在您的样本回购中,importLoaders=2同时使用Sass和PostCSS。