我正在尝试在我的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"
]
}
}
}
答案 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);
}