“compes”不使用babel-plugin-react-css-modules

时间:2017-01-07 06:16:00

标签: reactjs webpack babel css-modules react-css-modules

我正在尝试在我的React项目中使用css模块。我可以做以下事情:

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

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

我的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"
      ]
    }
  }
}

2 个答案:

答案 0 :(得分:1)

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

解决了这个问题

例如webpack.config.js

...
module : {
loaders : [
  {
    test : /\.jsx?/,
    include : APP_DIR,
    loader :  'babel-loader',
    query: 'cacheDirectory=false',
  },
...

答案 1 :(得分:0)

这里有同样的问题。我找到的解决方法是使用vars代替编写。

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

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

.button {
  color: var(--blue);
}