1

我有一个列表,每个项目都需要两个部分。我还需要第一部分的宽度是固定的。我应该如何编码?

我试过使用定义列表:

    <dl>
      <dt style="width: 2em;">foo</dt><dd>bar</dd>
    ...

    </dl>

...和具有跨度的用户列表:

    <ul>
      <li><span style="width: 2em;">foo<span>bar</li>
    ...

    </ul>

都没有奏效。有什么规范的方法可以做到这一点吗?

4

6 回答 6

2

就像 Alan 说的,但如果你只是放一个 div 它不会按照你想要的方式工作,试试这个:

<ul>
  <li><div style="width: 200px; display: inline-block;">foo</div>bar</li>
  <li><div style="width: 200px; display: inline-block;">foo12</div>bar</li>
  <li><div style="width: 200px; display: inline-block;">foo12345</div>bar</li>
  <li><div style="width: 200px; display: inline-block;">foo12345678</div>bar</li>
</ul>

(也许您想使用一个类而不是重复每个列表项的样式属性)

于 2009-05-24T07:16:20.940 回答
1

宽度不适用于<span>标签,因为它们是内联的。尝试用<div>or<p>或任何其他块元素替换标签。

于 2009-05-24T07:04:45.270 回答
1

使用 dl 并将 dt 浮动到左侧。

<style type="text/css">
dt {clear:left; float:left; width: 8em;}
</style>

<dl>
     <dt>foo<dt>
     <dd>bar</dd>
     <dt>foo1<dt>
     <dd>bar1</dd>
     <dt>foo12345<dt>
     <dd>bar</dd>
 </dl>
于 2009-05-24T10:53:10.927 回答
1

我想出的方法也许不是规范的(但只是因为我不相信有一种“规范”的方式来实现它),但它确实有效:

    <style type="text/css" media="screen">

        #container
            {width: 50%;
            margin: 0 auto;
            }

        ol,
        ul  {border: 1px solid #ccc;
            width: 90%;
            padding: 1.4em 0;
            }

        ol li,
        ul li   {background-color: #ccc;
            margin-left: 20%;
            }

        ol li span.list-head,
        ul li span.list-head
            {background-color: #ffa;
            float: left;
            display: block;
            width: 6em;
            }

        dl  {border: 1px solid #ccc;
            line-height: 1.4em;
            padding: 1.4em 0 0 0;
            }

        dl dt   {background-color: #ffa;
            display: block;
            margin: 0;
            width: 10%;
            }

        dl dd   {background-color: #fc0;
            display: block;
            margin: 0;
            width: 88%;
            margin-left: 11%;
            position: relative;
            top: -1.4em;
            }       

    </style>
...
    <div id="container">

        <ol>

            <li><span class="list-head">Foo:</span> bar.</li>

            <li><span class="list-head">Bar:</span> baz.</li>

            <li><span class="list-head">Baz:</span> foo.</li>

        </ol>

        <ul>

            <li><span class="list-head">Foo:</span> bar.</li>

            <li><span class="list-head">Bar:</span> baz.</li>

            <li><span class="list-head">Baz:</span> foo.</li>

        </ul>

        <dl>

            <dt>Foo:</dt>
            <dd>bar.</dd>

            <dt>Bar:</dt>
            <dd>baz.</dd>

            <dt>Baz:</dt>
            <dd>foo.</dd>

        </dl>

    </div>

有一个工作演示:http://www.davidrhysthomas.co.uk/so/lists.html

于 2009-05-24T11:38:14.483 回答
0

尝试第一部分的标签或内联 div

于 2009-05-24T07:16:50.283 回答
0

我想问:这是用于表示表格数据吗?我们一直被灌输认为 HTML 表格是邪恶的,但是对于显示数据表格来说,它们是完美的。我见过不止一位程序员尝试使用s 和 CSS来复制<table>标签的功能。<div>

当然,如果不是,那么请继续。:-)

于 2009-05-24T12:03:02.593 回答