添加交替的行颜色和列分组颜色 - 是否可能?

时间:2013-08-16 19:25:40

标签: jquery css

是否可以将GridView(与jQuery的tablesorter结合使用)设置为具有交替的行颜色,但是为每个列分组更改颜色集?见下图:

Example Image

我目前正基于我创建的阵列对单元格背景颜色进行硬编码,例如greenArray是一个设置为(0,1,2,3)的整数数组,purpleArray是(4,5,6,7)等。但是,当我使用tablesorter插件时,显然这些单元格会保留它们的颜色,这会使交替配色方案:

enter image description here

编辑:我目前正在VB.NET中添加背景颜色。以下函数定义数组,然后调用ColorizeMe()函数,该函数实际应用样式:

Private Sub StyleTable(ByVal sender As Object, ByVal e As GridViewRowEventArgs) Handles gvReport.RowDataBound

            'Define arrays to color the gridview, if cell index is in array, it will be colored
            Dim blueArray() As Integer = {0, 17, 18, 19, 20}
            Dim greenArray() As Integer = {1, 2, 3, 4}
            Dim purpleArray() As Integer = {5, 6, 7, 8}
            Dim pinkArray() As Integer = {9, 10, 11, 12}
            Dim yellowArray() As Integer = {13, 14, 15, 16}

            _packworks.ColorizeMe(blueArray, greenArray, purpleArray, pinkArray, yellowArray, e.Row)

End Sub

ColorizeMe()函数:

Public Sub ColorizeMe(ByVal blueArray() As Integer, ByVal greenArray() As Integer, _
                                 ByVal purpleArray() As Integer, ByVal pinkArray() As Integer, _
                                 ByVal yellowArray() As Integer, ByVal row As GridViewRow)
            Dim i As Integer = 0

            For Each cell As TableCell In row.Cells
                If Array.IndexOf(blueArray, i) <> -1 Then
                    If _isDark Then 'Color account column
                        cell.BackColor = ColorTranslator.FromHtml("#B0C4DE")
                    Else
                        cell.BackColor = ColorTranslator.FromHtml("#E6E6FA")
                    End If
                ElseIf Array.IndexOf(greenArray, i) <> -1 Then
                    If _isDark Then
                        cell.BackColor = ColorTranslator.FromHtml("#a4d5a8")
                    Else
                        cell.BackColor = ColorTranslator.FromHtml("#ddf5de")
                    End If
                ElseIf Array.IndexOf(purpleArray, i) <> -1 Then
                    If _isDark Then
                        cell.BackColor = ColorTranslator.FromHtml("#ada4d4")
                    Else
                        cell.BackColor = ColorTranslator.FromHtml("#c7c6f4")
                    End If
                ElseIf Array.IndexOf(pinkArray, i) <> -1 Then
                    If _isDark Then
                        cell.BackColor = ColorTranslator.FromHtml("#e3b3e0")
                    Else
                        cell.BackColor = ColorTranslator.FromHtml("#fae1fa")
                    End If
                ElseIf Array.IndexOf(yellowArray, i) <> -1 Then
                    If _isDark Then
                        cell.BackColor = ColorTranslator.FromHtml("#e0e3ab")
                    Else
                        cell.BackColor = ColorTranslator.FromHtml("#f5f8dd")
                    End If
                End If

                i += 1
            Next

            _isDark = Not _isDark
        End Sub

1 个答案:

答案 0 :(得分:2)

由于您的行是浅色/深色交替,您可以利用Alpha透明背景颜色:

http://cssdeck.com/labs/6rgab657

<table>
  <colgroup class="a" span="4" />
  <colgroup class="b" span="4" />
  <colgroup class="c" span="4" />
  <colgroup class="d" span="4" />

  <tr>
    <td>A</td>
    <td>A</td>
    <td>A</td>
    <td>A</td>
    <td>B</td>
    <td>B</td>
    <td>B</td>
    <td>B</td>
    <td>C</td>
    <td>C</td>
    <td>C</td>
    <td>C</td>
    <td>D</td>
    <td>D</td>
    <td>D</td>
    <td>D</td>
  </tr>

  <tr>
    <td>A</td>
    <td>A</td>
    <td>A</td>
    <td>A</td>
    <td>B</td>
    <td>B</td>
    <td>B</td>
    <td>B</td>
    <td>C</td>
    <td>C</td>
    <td>C</td>
    <td>C</td>
    <td>D</td>
    <td>D</td>
    <td>D</td>
    <td>D</td>
  </tr>
</table>

CSS:

.a {
  background: blue;
}

.b {
  background: green;
}

.c {
  background: purple;
}

.d {
  background: red;
}

tr:nth-child(odd) {
  background: rgba(255, 255, 255, .70);
}