3

我第一次尝试使用 React 和 Webpack 的 CSS 模块,我遇到了至少三种实现它的方法:

  1. CSS加载器
  2. 反应 CSS 模块
  3. babel-plugin-react-css-modules

babel-plugin-react-css-modules为了平衡代码的简单性和性能,我选择了它,除了一件事之外,一切似乎都运行良好:我的第 3 方库(Bootstrap 和 Font Awesome)也包含在 CSS 模块转换中。

<NavLink to="/about" styleName="navigation-button"></NavLink>

上面将适当转换classNameNavLink. 但是,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';
4

3 回答 3

5

我发现以下这两种方法可能会有所帮助:

简而言之,到目前为止,似乎没有选项可以忽略/排除某些路径被 css-modules webpack 插件模块化。理想情况下,插件应该支持它,但是您可以尝试以下一些方法:

使用两个 webpack 规则来利用 webpack 规则排除/包含

module.exports = {
  rules: [
    {
      test: /\.css$/,
      exclude: /node_modules/,
      use: [
        'style-loader',
        {
          loader: 'css-loader',
          options: {
            modules: true,
            localIdentName: '[path]__[local]___[hash:base64:5]',
          },
        },
      ],
    },
    {
      test: /\.css$/,
      include: /node_modules/,
      use: ['style-loader', 'css-loader']
    }
  ]
}

...或者,从上面的第二个答案中注入 webpack 的 getLocalIdent以手动排除某些路径。

const getLocalIdent = require('css-loader/lib/getLocalIdent');

{
  loader: 'css-loader',
  options: {
    modules: true,
    localIdentName: '[path][name]__[local]--[hash:base64:5]',
    getLocalIdent: (loaderContext, localIdentName, localName, options) => {
      return loaderContext.resourcePath.includes('semantic-ui-css') ?
        localName :
        getLocalIdent(loaderContext, localIdentName, localName, options);
    }
  }
}
于 2018-12-14T14:05:55.327 回答
3

对我来说使用:global工作:

.my-component {
    :global {
        .external-ui-component {
           padding: 16px;
           // Some other styling adjustments here
        }
        ...
    }
}

Ps:要使用 webpack config 进行操作,请参阅另一个答案。

资源

于 2020-10-30T15:56:04.493 回答
2

play771更新的解决方案

 {
    loader: 'css-loader',
    options: {
      modules: {
        auto: (resourcePath) => !resourcePath.includes('node_modules'),
        localIdentName: '[name]__[local]__[hash:base64:5]',
      },
    },
 },
于 2021-02-07T21:55:03.420 回答