jQuery addClass无法正常工作

时间:2009-07-27 13:34:08

标签: jquery addclass

我正在尝试使用addClass在我的Joomla模板上为我提供斑马条纹表。我使用以下代码:

 <script>
  jQuery(function($) {
    $("tr:odd").addClass("odd");
  });
</script>

我已经能够使用tr:odd选择器动态地将css添加到表行,但是当我使用addClass函数时它只是不行(我检查了生成的源代码,并且没有表行具有类“奇“)。

我不知道自己可能做错了什么,不胜感激任何帮助。

5 个答案:

答案 0 :(得分:24)

因此,您知道,当您查看源代码时,不会反映使用Javascript对DOM进行的更改。

如果您的CSS看起来像这样,该代码应该有用......

tr.odd td
{
    background:#070;
}

答案 1 :(得分:9)

这里有两种创建斑马条纹的方式/方法,一种是使用jQuery,另一种是使用CSS3。

第一种方法 - 使用jQuery

<强> HTML

要创建“条带化”表格,我们需要创建一个带有ID的表来识别它,并将该样式仅应用于该表格,在本例中我们将其命名为“ zebra_triped

<table id="zebra_triped" cellpadding="1" cellspacing="1" >
    <tr>
        <td>Lorem ipsum dolor sit amet</td>
        <td>Lorem ipsum dolor sit amet</td>
    </tr>
    <tr>
        <td>Lorem ipsum dolor sit amet</td>
        <td>Lorem ipsum dolor sit amet</td>
    </tr>
    <tr>
        <td>Lorem ipsum dolor sit amet</td>
        <td>Lorem ipsum dolor sit amet</td>
    </tr>
    <tr>
        <td>Lorem ipsum dolor sit amet</td>
        <td>Lorem ipsum dolor sit amet</td>
    </tr>
    <tr>
        <td>Lorem ipsum dolor sit amet</td>
        <td>Lorem ipsum dolor sit amet</td>
    </tr>
</table>

<强> CSS

我们为偶数行创建一个样式,为奇数行创建另一个样式。

<style type="text/css">
  html, body { font: 12px verdana; color: #333; }  
  table { background-color: white; width: 100%; }
  .oddRow { background-color:#ffcc00; } 
  .evenRow { background-color:#cccccc; }
</style>

<强> 的jQuery

最后,我们需要创建将CSS类添加到tr标签的jQuery代码,这可以通过以下代码实现:

<script type="text/javascript">  
   $(document).ready(function() {  
   $("#stripedTable tr:odd").addClass("oddRow");  
   $("#stripedTable tr:even").addClass("evenRow");  
});  
</script>

第一行选择id为zebra_triped的元素中的奇数tr标签,并将它们添加为“oddRow”类,最后一行与偶数行相同,将它们添加为“evenRow”类。

第二种方法 - 使用CSS

**我的最爱:) *

<强> HTML

<div id="comments">
    <h3>Comments</h3>
    <div class="comments_body">
        <header>By: <a href="#"> Lorem ipsum </a></header>
        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit,.</p>
    </div>
    <div class="comments_body">
        <header>By: <a href="#"> Lorem ipsum </a></header>
        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, </p>
    </div>
    <div class="comments_body">
        <header>By: <a href="#"> Lorem ipsum </a></header>
        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, </p>
    </div>
    <div class="comments_body">
        <header>By: <a href="#"> Lorem ipsum </a></header>
        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, </p>
    </div>
    <div class="comments_body">
        <header>By: <a href="#"> Lorem ipsum </a></header>
        <p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, </p>
    </div>
</div>

<强> CSS

<style type="text/css">
  html, body { font: 12px verdana; color: #333; }
  table { background-color: white; width: 100%; }
  #comments { margin-top: 21px; padding-top: 10px; border-top: 1px solid #d7d7d7; }
  #comments .comments_body { display: table; padding: 10px; }

   #comments .comments_body:nth-child(odd) {
    padding: 21px;
    background: #E3E3E3;
    border: 1px solid #d7d7d7;
   -moz-border-radius: 11px; // support FireFox which runs on Mozilla engine
   -webkit-border-radius: 11px; // support Safari and Chrome which they run on WebKit engine
   // as usual IE is behind and no support for it yet, unless you need to hack it using Java Script.
  }
</style>

- moz -border-radius:11px; - webkit -border-radius:11px; 在这里,我为每个角定义容器边框的半径/圆角。 这只是一行指定所有角落的半径属性,但我可以如下所示定位特定角落:

- moz -border-radius-bottomleft:11px;
- moz -border-radius-bottomright:11px;
- moz -border-radius-topleft:11px;
- moz -border-radius-topright:11px;

- webkit -border-radius-bottomleft:11px;
- webkit -border-radius-bottomright:11px;
- webkit -border-radius-topleft:11px;
- webkit -border-radius-topright:11px;

希望这有帮助,

艾哈迈德

答案 2 :(得分:3)

jQuery不会更改HTML文档的源代码,它会更改DOM结构(文档的内存表示)。要查看这些更改,您必须使用显示文档DOM的浏览器插件(适用于Firefox的Firebug,适用于IE的开发人员工具(F12))。

答案 3 :(得分:1)

尝试将类添加到td,而不是像这样:

$("tr:odd td").addClass("odd");

答案 4 :(得分:0)

 $('table tr').each(function() {
    if ($(this).find('td').eq(6).text() === 'Start') {
        $(this).addClass('tooltip');
    }
 });