我第一次尝试使用 React 和 Webpack 的 CSS 模块,我遇到了至少三种实现它的方法:
babel-plugin-react-css-modules
为了平衡代码的简单性和性能,我选择了它,除了一件事之外,一切似乎都运行良好:我的第 3 方库(Bootstrap 和 Font Awesome)也包含在 CSS 模块转换中。
<NavLink to="/about" styleName="navigation-button"></NavLink>
上面将适当转换className
的NavLink
. 但是,span
内部需要引用全局样式才能呈现图标。
<span className="fa fa-info" />
上面的跨度没有分配一个className
预期的转换,但是我捆绑的样式表没有这些 CSS 类,因为它们被转换成其他东西,以模拟本地范围。
以下是我.babelrc
要激活的文件中的内容babel-plugin-react-css-modules
:
{
"presets": ["env", "react"],
"plugins": [
["react-css-modules", {
"generateScopedName": "[name]__[local]___[hash:base64:5]",
"filetypes": {
".less": {
"syntax": "postcss-less"
}
}
}]
]
}
在我的 Webpack 配置中,下面是css-loader
为转换配置的部分:
{
test: /\.(less|css)$/,
exclude: /node_modules/,
use: extractCSS.extract({
fallback: 'style-loader',
use: [
{
loader: 'css-loader',
options: {
minimize: true,
modules: true,
sourceMap: true,
localIdentName: '[name]__[local]___[hash:base64:5]'
}
},
{
loader: 'less-loader'
}
]
})
}
据我所读,上述规则应排除库样式表,我还尝试专门为排除的样式表添加另一条规则,但这似乎不起作用,因为我猜这些样式表仍使用原始规则进行转换。
为了从这两个库中导入 CSS,我的父样式表中有以下两行声明了一些全局样式:
@import '../../../node_modules/bootstrap/dist/css/bootstrap.min.css';
@import '../../../node_modules/font-awesome/css/font-awesome.min.css';