奇数/偶数CSS到位时的主行标题颜色

时间:2014-03-19 11:00:59

标签: javascript jquery css html-table

我有一个展开/折叠表,可以在展开/折叠时自动调整奇数/偶数行颜色(深灰色和浅灰色)..

我想要实现的是,对于某些特定的行,我需要应用背景颜色(我使用的类是mainRow)。但是,由于我的Javascript函数,我相信这是在制作CSS无法按预期执行。

这是我的小提琴:http://jsfiddle.net/oampz/JNQx4/1/

HTML:

<table class="tbl tbl--highlight stripes half-mb">
<thead>
    <tr>
        <th>Name</th>
        <th>Age</th>
        <th>Height</th>
        <th>Weight</th>
    </tr>
</thead>
<tbody>
    <tr class="mainRow">
        <td class="ShowMe">+ 0000111</td>
        <td>0000111</td>
        <td>0000111</td>
        <td>0000111</td>
    </tr>
    <tr id="itsHidden" class="visuallyhidden">
        <td>0000222</td>
        <td>0000222</td>
        <td>0000222</td>
        <td>0000222</td>
    </tr>
    <tr>
        <td>0000333</td>            
        <td>0000333</td>
        <td>0000333</td>
        <td>0000333</td>
    </tr>
    <tr>
        <td>0000444</td>
        <td>0000444</td>
        <td>0000444</td>
        <td>0000444</td>
    </tr>
    <tr class="mainRow">
        <td class="ShowMe">+ 0000555</td>            
        <td>0000555</td>
        <td>0000555</td>
        <td>0000555</td>
    </tr>
    <tr id="itsHidden2" class="visuallyhidden">
        <td>0000666</td>            
        <td>0000666</td>
        <td>0000666</td>
        <td>0000666</td>
    </tr>
    <tr>
        <td>0000777</td>            
        <td>0000777</td>
        <td>0000777</td>
        <td>0000777</td>
    </tr>
</tbody>
</table>

CSS:

table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}
th {
    min-width: 22px;
}
.stripes tbody > tr.odd {
    background: #f2f2f2;
}
.stripes li:nth-child(2n) {
    background: #f2f2f2;
}
.tbl {
    border: 1px solid #d1d1d1;
    font-size: 12px;
    font-size: 0.75rem;
    line-height: 2;
    clear: both;
}
.tbl th, .tbl td {
    padding: 3px;
    text-align: left;
    border-right: 1px solid #d1d1d1;
}
.tbl th {
    border-bottom: 1px solid #d1d1d1;
}
.tbl--highlight tbody tr:hover {
    background: #d4e8fc;
    cursor: pointer;
}
.tbl--input td {
    overflow: hidden;
}
.half-mb {
    margin: 0 0 12px 0;
}

.visuallyhidden {
  display: none;
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
  display: block;
}

.mainRow {
 background-color: #0c5cac;  
}

使用Javascript:

$(function(){
    function stripeTable(){
         $("table.stripes tr").removeClass("odd");
         $("table.stripes tr:visible:odd").addClass("odd"); 
    }
    stripeTable();

    $(".ShowMe").click(function() {

        $("#itsHidden").toggleClass("visuallyhidden");
        $("#itsHidden2").toggleClass("visuallyhidden");
        stripeTable();
    });
});

任何帮助表示赞赏

1 个答案:

答案 0 :(得分:1)

不确定你的问题究竟是什么。

如果您希望mainRow行始终为蓝色,那么它只是CSS中的特定问题。奇数类和mainRow类都设置了背景,奇数选择器具有更多的特殊性。

简单的解决方案是在后面添加一个重要的

.mainRow {
    background-color: #0c5cac !important;  
}

有人说使用!important是一个坏习惯。但是,作为生活中的一切,我认为有时它是解决问题的更简单方法,这可能就是其中之一。

updated fiddle