20

是否可以仅在有序列表上设置样式或增加数字的大小?

我打算将有序列表ol变成仅使用 CSS的wikihow步骤之类的东西。

这是一个可以玩的例子:http: //jsfiddle.net/ejRzy/1/

4

2 回答 2

43

它可以使用 CSS3 但不是 100% 跨浏览器(即 IE7)来完成。使用伪 :before 元素和 counter-reset 和 counter-increment 您可以隐藏列表样式并创建自己的样式。

这是一篇概述如何的文章:样式化有序列表编号

是从那篇文章构建的演示。

同样在可怕的链接腐烂的情况下 - 这是所需的主要 CSS 代码(这可以应用于任何有序列表)

ol {
    counter-reset:li; /* Initiate a counter */
    margin-left:0; /* Remove the default left margin */
    padding-left:0; /* Remove the default left padding */
}
ol > li {
    position:relative; /* Create a positioning context */
    margin:0 0 6px 2em; /* Give each list item a left margin to make room for the numbers */
    padding:4px 8px; /* Add some spacing around the content */
    list-style:none; /* Disable the normal item numbering */
    border-top:2px solid #666;
    background:#f6f6f6;
}
ol > li:before {
    content:counter(li); /* Use the counter as content */
    counter-increment:li; /* Increment the counter by 1 */
    /* Position and style the number */
    position:absolute;
    top:-2px;
    left:-2em;
    -moz-box-sizing:border-box;
    -webkit-box-sizing:border-box;
    box-sizing:border-box;
    width:2em;
    /* Some space between the number and the content in browsers that support
       generated content but not positioning it (Camino 2 is one example) */
    margin-right:8px;
    padding:4px;
    border-top:2px solid #666;
    color:#fff;
    background:#666;
    font-weight:bold;
    font-family:"Helvetica Neue", Arial, sans-serif;
    text-align:center;
}
li ol,
li ul {margin-top:6px;}
ol ol li:last-child {margin-bottom:0;}​

此代码将生成一个自定义排序列表;尽管不是您要求的样式。我将把定制工作留给你 :) 干杯

于 2012-06-25T03:02:47.490 回答
13

有点....用您想要的数字字体大小为您的有序列表设置样式,然后将所有列表项包装在跨度中,并为它们提供不同的样式。

http://jsfiddle.net/keith_nicholas/MEHXj/

于 2012-06-25T02:23:15.797 回答