首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >"composes“不适用于babel-plugin-react-css-modules

"composes“不适用于babel-plugin-react-css-modules
EN

Stack Overflow用户
提问于 2017-01-07 14:16:00
回答 2查看 1.2K关注 0票数 4

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

代码语言:javascript
复制
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中添加"composes“时,它可以工作。我看不出我的代码和演示中的代码有什么不同。

我的webpack加载器是:

代码语言:javascript
复制
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:

代码语言:javascript
复制
{
  presets: [
    "es2015",
    "react",
  ],

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

回答 2

Stack Overflow用户

发布于 2017-01-18 19:58:03

这里也有同样的问题。我发现的解决办法是使用vars而不是composes。

代码语言:javascript
复制
/* colors.css */
:root {
  --color: #4A90E2
}

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

.button {
  color: var(--blue);
}
票数 1
EN

Stack Overflow用户

发布于 2017-08-24 04:12:02

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

例如webpack.config.js

代码语言:javascript
复制
...
module : {
loaders : [
  {
    test : /\.jsx?/,
    include : APP_DIR,
    loader :  'babel-loader',
    query: 'cacheDirectory=false',
  },
...
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41518465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档