CSS模块中未生成的类名选择器

时间:2020-07-23 09:54:33

标签: css css-modules react-css-modules

假设我们有这样的第三方CardComponent

<Card title="This is a title in the header">This is text in the body</Card>

这会以纯HTML呈现

<div class="Card">
  <div class="CardHeader"></div>
  <div class="CardBody"></div>
</div>

我正在使用css模块进行样式设置(在这种情况下为scss)。

.customCard {
  .CardBody {
    color: red;
  }
}

然后将类添加到Card

import styles from ...
...
<Card className={styles.customCard} ...>...</Card>

上面的方法不起作用,因为它为CardBody创建了一个生成的类,例如CardBody_sjkdh43。有没有办法在模块中选择未生成的类名?还是只能以旧的方式使用样式表?

Demo SandBox

1 个答案:

答案 0 :(得分:1)

这是一个老问题,但答案是 css 模块中的 :global() 选择器。

更多信息:Exceptions - CSS Modules

示例代码:

<div class={styles.myClass}>
    <SomeComponentWithOwnCss />
</div>

输出:

<div class="myClass_s4jkdh3">
    <div class="SomeComponentWithOwnCss"></div>
</div>  

和 CSS:

.myClass div:global(.SomeComponentWithOwnCss) {
    background-color: red;
}

此处的工作示例:codesandbox