首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么我的颜色会被css-模块覆盖?

为什么我的颜色会被css-模块覆盖?
EN

Stack Overflow用户
提问于 2016-04-04 16:40:58
回答 1查看 44关注 0票数 1

当我使用CSS时,我试图理解为什么我的颜色会在css-modules中被覆盖。这是我的jsx

代码语言:javascript
复制
let tabLink = className({
    [s.selected]: selectTab
});

<li className={s.tabs}>
    <a className={tabLink}>{tab.translation}</a>
</li>

这是CSS

代码语言:javascript
复制
.tabs {
    color: #454545;
}
.tabs li {
    display: inline-block;
    font-size: 11px;
}
.tabs li a {
    color: #454545;
    cursor: pointer;
    text-decoration: none;
}
.selected {
    background: url('../../images/header_nav_on.gif') top left repeat-x;
    color: white;
}

因此,当selectTab为true时,则将s.selected应用于元素。在这种情况下,colorwhite,但它不应用于元素。在color中定义的.tab li a正在覆盖它。我不得不将!important添加到white中,以使其成为color。我对csscss-modules有什么不了解?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-04-04 18:22:24

.tabs li a.selected更具体。如果希望.selected覆盖默认值,请尝试.tabs .selected { background: url('../../images/header_nav_on.gif') top left repeat-x; color: white; }

您可以使用以下公式计算专用性: id +100,类+10,标记+1。

这使得.tabs li a值为12 (class( 10 ) + tag(1) + tag(1))和.selected,后者仅为10。如果将其改为.tabs .selected,则它将值20 (类(10)+类(10)),并将其置于默认值之上。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/36408255

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档