3

我需要将表格设置为斑马,甚至表格行的样式,我使用了 css :nth-of-type(even)。但是例如当我需要隐藏表格的一些程式化元素时,就会丢失。将动态样式创建为桌子的斑马线的最简单方法是什么?

<!DOCTYPE html>
<html>
<head>
  <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.min.js"></script>
  <style type="text/css">
    table tr:nth-of-type(even){background: yellow;}
  </style>
  <script type="text/javascript">
    function hideRow(){
      $(".hidden").hide();
    }
  </script>
</head>
<body>
<center>
 <table cellspacing="0" border="1">
     <tbody>
    <tr class="table-row">
      <td>row1</td>
    </tr>
    <tr class="table-row">
      <td>row2</td>
    </tr>
    <tr class="table-row hidden">
      <td>row3</td>
    </tr>
    <tr class="table-row">
      <td>row4</td>
    </tr>
    <tr class="table-row">
      <td>row5</td>
    </tr>
    </tbody>
 </table>
 <input type="submit" onclick=" hideRow()" value="submit"/> 
 </center>
</body>
</html>

如何动态更改表格的样式?

当前结果:
在此处输入图像描述 在此处输入图像描述
预期结果:
在此处输入图像描述 在此处输入图像描述

4

3 回答 3

1

当您隐藏元素时,它仍然存在(只是隐藏),这就是您遇到此问题的原因。我建议您针对 css:nth-of-type(even)选择器创建简单的脚本。首先,两个类:

.table_odd { color: yellow; } 
.table_even {color: white; }

现在克里特功能:

function refrestTableColoring( $tableSelector ) {
    $tableSelector.find('tr:odd:not(.hidden)').removeClass('table_even').addClass('table_odd');
    $tableSelector.find('tr:even:not(.hidden)').removeClass('table_odd').addClass('table_even'); 
}

然后使用很简单。准备好文档并在隐藏元素时调用:

refrestTableColoring( $('table') );
于 2013-01-22T13:29:55.520 回答
0
 table tr[@display=block]:nth-of-type(even){background: yellow;}

这行得通吗?

免责声明:未经测试

于 2013-01-22T13:28:51.327 回答
0

您可以使用remove()而不是hide()。像这样写:

$('input[type="submit"]').click(function(){
    $(".hidden").remove();
});

检查这个http://jsfiddle.net/fhbgM/

于 2013-01-22T13:34:50.757 回答