我有以下html标记:
<div class="header-menu">
<span class="header-title noselect">
<i class="fa fa-bars"></i>
<a href="/" class="header-title-value">
{{ headerVm.menu.current.title }}
</a>
</span>
</div>
*.less
档案中的此规则:
.header-menu {
.header-title {
color: red;
a {
font-size: 2em;
font-family: 'Roboto', sans-serif;
font-weight: 300;
}
}
}
被翻译成css:
.header-menu .header-title{
cursor:pointer;
color:#f00
}
.header-menu .header-title a {
font-size:2em;
font-family:'Roboto',sans-serif;
font-weight:300
}
在这种情况下,color
的{{1}}属性不会影响header-title
代码,但如果我将其置于a
规则中,则可以使用a
。此外,我试图在!improtant
属性上设置color
,这也没有帮助。另一个有趣的时刻,如果我从a
规则移动字体属性并将它们放入.header-menu .header-title
这将适用于a
标记,但不适用于color
属性。< / p>
在Chrome检查器中,我看到a
的规则来自bootstrap的规则,而不是来自header-title
。实际上我对如何解决这个问题并不感兴趣,但为什么它的工作方式和正确的修复/最佳实践建议也是如此?)
答案 0 :(得分:7)
默认情况下,<a>
标记不会从其父元素继承颜色。试试这个来强制继承:
.header-menu {
.header-title {
color: red;
a {
color: inherit;
font-size: 2em;
font-family: 'Roboto', sans-serif;
font-weight: 300;
}
}
}
答案 1 :(得分:1)
您需要为a标签指定color属性和值以查看其效果