我正在尝试在我的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中添加"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"
]
}
}
}发布于 2017-01-18 19:58:03
这里也有同样的问题。我发现的解决办法是使用vars而不是composes。
/* colors.css */
:root {
--color: #4A90E2
}
/* button.css */
@import 'colors.css';
.button {
color: var(--blue);
}发布于 2017-08-24 04:12:02
我遇到了这个问题,发现可以通过添加cacheDirectory: false来解决这个问题
例如webpack.config.js
...
module : {
loaders : [
{
test : /\.jsx?/,
include : APP_DIR,
loader : 'babel-loader',
query: 'cacheDirectory=false',
},
...https://stackoverflow.com/questions/41518465
复制相似问题