0

如果 ol 中的 ol 格式如下所示,则很容易获得正确的计数

 <ol>
  <li>item</li> 
  <li>item             
    <ol>
      <li>item</li>     
      <li>item</li>    
      <li>item          
    </ol>
  </li>
  <li>item</li>        
  <li>item</li>      
  <li>item
     <ol>
      <li>item</li>      
      <li>item</li>      
      <li>item         
    </ol>
   </li>        
  <li>item</li>       
</ol>

但是,如果我想将 ul 放在 ol 中,我无法让计数器正常工作

  <ol>
  <li>item</li> 
  <li>item             
    <ul>
      <li>item</li>     
      <li>item</li>    
      <li>item          
    </ul>
  </li>
  <li>item</li>        
  <li>item</li>      
  <li>item
     <ul>
      <li>item</li>      
      <li>item</li>      
      <li>item         
    </ul>
   </li>        
  <li>item</li>       
</ol>

http://jsfiddle.net/jaxymnh8/

在此处输入图像描述

有没有办法避免计算 ul ?

4

2 回答 2

7

有一个非常简单的方法来修复它。只需使用 CSS 子选择器 ( ) >,因此计数仅包括.<li><ol>

ol > li::before {
  counter-increment: my;
  content: counter(my) ; 
  margin-right: 10px;
}

http://jsfiddle.net/jaxymnh8/1/

于 2015-09-04T01:45:58.540 回答
2

您需要为子添加一个计数器li

所以你会这样做

ol,ul {
    list-style:none;
}
.count{
    counter-reset: section;
}

ol>li {
    counter-reset: subsection;
}

ol>li:before {
    counter-increment: section;
    content: counter(section) ". ";
}

ul li:before {
    counter-increment: subsection;
    content: counter(section) "." counter(subsection) " ";
}

JSFIDDLE

于 2015-09-04T01:42:20.753 回答