Как я могу стилизовать четные и нечетные элементы?

281

Можно ли использовать псевдоклассы CSS для выбора четных и нечетных экземпляров элементов списка?

Я ожидал бы, что следующее произведет список чередующихся цветов, но вместо этого я получу список синих элементов:

<html>
    <head>
        <style>
            li { color: blue }
            li:odd { color:green }
            li:even { color:red }
        </style>
    </head>
    <body>
        <ul>
            <li>ho</li>
            <li>ho</li>
            <li>ho</li>
            <li>ho</li>
            <li>ho</li>
        </ul>
    </body>
</html>
Armand
источник

Ответы:

630

Демо: http://jsfiddle.net/thirtydot/K3TuN/1323/

li {
    color: black;
}
li:nth-child(odd) {
    color: #777;
}
li:nth-child(even) {
    color: blue;
}
<ul>
    <li>ho</li>
    <li>ho</li>
    <li>ho</li>
    <li>ho</li>
    <li>ho</li>
</ul>

Документация:

thirtydot
источник
33
Только примечание: nth-child не поддерживается IE 8 и ниже.
MEM
1
Вы можете использовать полифилл Selectivzr, если вам нужно также поддерживать IE8 ... и IE6 / 7.
Рикардо Зеа
2
Просто подтвердил, что даже с Selectivizr :nth-child(odd/even)не работает в IE8.
Рикардо Зеа
7
Правда, он не работает в IE8, как описано здесь: caniuse.com/#feat=css-sel3, но он работает на всех основных браузерах .
кодирование
1
В конце концов, в этом случае больше не о чем беспокоиться о поддержке IE8, поскольку предполагаемое поведение просто «поддерживающее». Это не мешает пользователю использовать сайт или находить информацию. Это даже (скорее всего, не) портит внешний вид сайта.
Хафенкранич
47

Проблема с вашим CSS связана с синтаксисом ваших псевдоклассов.

Четные и нечетные псевдоклассы должны быть:

li:nth-child(even) {
    color:green;
}

и

li:nth-child(odd) {
    color:red;
}

Демо: http://jsfiddle.net/q76qS/5/

Кевин Герни
источник
18

Использовать это:

li { color:blue; }
li:nth-child(odd) { color:green; }
li:nth-child(even) { color:red; }

Информацию о поддержке браузера смотрите здесь: http://kimblim.dk/css-tests/selectors/

Дэн С
источник
3

li:nth-child(1n) { color:green; }
li:nth-child(2n) { color:red; }
<ul>
  <li>list element 1</li>
  <li>list element 2</li>
  <li>list element 3</li>
  <li>list element 4</li>
</ul>

Смотрите поддержку браузера здесь: CSS3: nth-child () Selector

iDaniel88
источник
1

css нечетный и даже не поддерживает IE. рекомендуем использовать решение ниже.

Лучшее решение:

li:nth-child(2n+1) { color:green; } // for odd
li:nth-child(2n+2) { color:red; } // for even

li:nth-child(1n) { color:green; }
li:nth-child(2n) { color:red; }
<ul>
  <li>list element 1</li>
  <li>list element 2</li>
  <li>list element 3</li>
  <li>list element 4</li>
</ul>
Minh_Bu
источник
0

Ниже приведен пример применения четного и нечетного цвета CSS

<html>
<head>
<style> 
p:nth-child(even) {
    background: red;
}
p:nth-child(odd) {
    background: green;
}
</style>
</head>
<body>

<p>The first Odd.</p>
<p>The second Even.</p>
<p>The third Odd.</p>
<p>The fourth Even.</p>


</body>
</html>
Шео Дайал Сингх
источник
0

но это не работает в IE. рекомендуем использовать: nth-child (2n + 1): nth-child (2n + 2)

li {
    color: black;
}
li:nth-child(odd) {
    color: #777;
}
li:nth-child(even) {
    color: blue;
}
<ul>
    <li>ho</li>
    <li>ho</li>
    <li>ho</li>
    <li>ho</li>
    <li>ho</li>
</ul>

Minh_Bu
источник
0

Селектор: nth-child (n) соответствует каждому элементу, который является n-ным дочерним элементом, независимо от типа, его родителя. Нечетными и четными являются ключевые слова, которые можно использовать для сопоставления дочерних элементов, индекс которых нечетен или четен (индекс первого дочернего элемента равен 1).

это то, что вы хотите:

<html>
    <head>
        <style>
            li { color: blue }<br>
            li:nth-child(even) { color:red }
            li:nth-child(odd) { color:green}
        </style>
    </head>
    <body>
        <ul>
            <li>ho</li>
            <li>ho</li>
            <li>ho</li>
            <li>ho</li>
            <li>ho</li>
        </ul>
    </body>
</html>
Агбула Фейикеми
источник
-5
 <ul class="names" id="names_list">
          <a href="javascript:void(0);"><span class="badge">1</span><li class="part1" id="1">Ashwin Nair</li></a>
           <a href="javascript:void(0);"><span class="badge">2</span><li class="part2" id="2">Anil Reddy</li></a>
           <a href="javascript:void(0);"><span class="badge">0</span><li class="part1" id="3">Chirag</li></a>
           <a href="javascript:void(0);"><span class="badge">0</span><li class="part2" id="4">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">0</span><li class="part1" id="15">Ashwin</li></a>
            <a href="javascript:void(0);"><span class="badge">0</span><li class="part2" id="16">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">5</span><li class="part1" id="17">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">6</span><li class="part2" id="18">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">1</span><li class="part1" id="19">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">2</span><li class="part2" id="188">Anil Reddy</li></a>
           <a href="javascript:void(0);"><span class="badge">0</span><li class="part1" id="111">Bhavesh</li></a>
           <a href="javascript:void(0);"><span class="badge">0</span><li class="part2" id="122">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">0</span><li class="part1" id="133">Ashwin</li></a>
            <a href="javascript:void(0);"><span class="badge">0</span><li class="part2" id="144">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">5</span><li class="part1" id="199">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">6</span><li class="part2" id="156">Ashwin</li></a>
           <a href="javascript:void(0);"><span class="badge">1</span><li class="part1" id="174">Ashwin</li></a>

         </ul>    
$(document).ready(function(){
      var a=0;
      var ac;
      var ac2;
        $(".names li").click(function(){
           var b=0;
            if(a==0)
            {
              var accc="#"+ac2;
     if(ac=='part2')
     {
    $(accc).css({

    "background": "#322f28",
    "color":"#fff",
    });
     }
     if(ac=='part1')
     {

      $(accc).css({

      "background": "#3e3b34",
      "color":"#fff",
    });
     }

              $(this).css({
                "background":"#d3b730",
                "color":"#000",
            });
              ac=$(this).attr('class');
              ac2=$(this).attr('id');
    a=1;
            }
            else{

    var accc="#"+ac2;
    //alert(accc);
     if(ac=='part2')
     {
    $(accc).css({

    "background": "#322f28",
    "color":"#fff",
    });
     }
     if(ac=='part1')
     {

      $(accc).css({

      "background": "#3e3b34",
      "color":"#fff",
    });
     }

     a=0;
    ac=$(this).attr('class');
    ac2=$(this).attr('id');
    $(this).css({
                "background":"#d3b730",
                "color":"#000",
            });

            }

        });
Ашвин Винод Кришнан
источник
3
Это просто ... ужасно. Есть так много лучших способов нацеливания на четные / нечетные элементы. Более того, нет никакой причины использовать такой JavaScript, когда две строки CSS будут выполнять одно и то же.
Дастин Холстед