html - 使用 CSS #Part II 在 HTML 中自动生成编号列表

标签 html css

my previous question ,我一直在使用 CSS 为 <li></li> 创建自动生成的列表编号标签。在另一项任务中,我需要创建另一个列表,其标题位于列表之间,如下图所示。

Example

上面的例子可以用下面的代码实现

HTML

<ol class="main">
    <span class="title">Title</span>
    <li>
        Content
    </li>
    <li>
        Content
    </li>
    <span class="title">Title</span>
    <li>
        Content
    </li>
</ol>

CSS

ul {counter-reset:section}
li {margin:15px 0;text-align:justify}
li:before {counter-increment:section;content:""}
.main {list-style-position:inside;list-style-type:none;padding:0}
.main span {font-weight:700;text-decoration:underline}
.inner {padding:0}
.inner ul {counter-reset:section}
.inner ul > li:before {content:""}
ul {list-style-type:lower-alpha}

但是,此代码在某些浏览器(如 Opera)中不起作用。这是因为在 HTML 5 中,<span></span>标签不能嵌套在元素 <ol></ol> 中.

jsFiddle适用于 Firefox、Chrome 和 Internet Explorer。

最佳答案

Here's a pure CSS version适用于 Chrome 26 和 FF 20(尚未在其他浏览器上测试)。与您之前的问题不同的是,您不需要每次都重置计数器。

/* Don't reset every time!!! */
/* ol.inner {counter-reset:section;} */

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

关于html - 使用 CSS #Part II 在 HTML 中自动生成编号列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16564291/

相关文章:

jquery - 响应式图像缩放到屏幕宽度并保持其比例

javascript - 如何检查 <li> 元素是否具有特定值

javascript - 将 DIV 附加到另一个 DIV 的一侧

css - 为什么 Firefox 忽略来自@font-face 的自定义字体?

css - 仅在 IE8 上出现的额外空白

javascript - 使用 jQuery slider 通过串行发送数据

jquery - 将 div 放置在通知中心正下方

java - 抢强标签Jsoup后的号码

html - 表格,允许一列有很多空间,同时强制其他列具有相同的宽度

javascript - anchor 标签可跨屏幕宽度点击