4

我正在尝试在我的 React 项目中使用 css 模块。我能够执行以下操作:

import styles from './demo.css'
const Demo = () => <div styleName="demo">Hello</div>

我的样式是从 CSS 中提取并成功添加前缀的。但是,当我尝试使用 CSS 模块的“组合”功能时,它似乎被完全忽略了。我什至没有从其他文件导入 - 只是试图编写本地类。但是,当我克隆演示项目(https://github.com/gajus/babel-plugin-react-css-modules/tree/master/demo)并在 CSS 中添加“composes”时,它可以工作。我看不出我的代码和演示中的代码有什么区别......

我的 webpack 加载器是:

loaders: [
      {
        test: /\.jsx?$/,
        loader: 'babel?cacheDirectory',
        include: PATHS.src
      },
      {
        test: /\.css$/,
        loaders: [
          'style',
          'css?importLoader=1&modules&localIdentName=[path]___[name]__[local]___[hash:base64:5]',
        ],
        include: PATHS.src,
      }
    ]

这是我的 .babelrc:

{
  presets: [
    "es2015",
    "react",
  ],

  plugins: [
    [
      "react-css-modules",
      {
        generateScopedName: "[path]___[name]__[local]___[hash:base64:5]"
      }
    ],
    "transform-object-rest-spread",
  ],
  env: {
    development: {
      presets: [
        "react-hmre"
      ]
    }
  }
}
4

2 回答 2

1

我遇到了这个问题,发现通过添加解决了cacheDirectory: false

例如webpack.config.js

...
module : {
loaders : [
  {
    test : /\.jsx?/,
    include : APP_DIR,
    loader :  'babel-loader',
    query: 'cacheDirectory=false',
  },
...
于 2017-08-23T20:12:01.737 回答
1

这里有同样的问题。我发现的解决方法是使用 vars 代替 composes。

/* colors.css */
:root {
  --color: #4A90E2
}

/* button.css */
@import 'colors.css';

.button {
  color: var(--blue);
}
于 2017-01-18T11:58:03.367 回答