Организация списков в HTML / CSS - PullRequest
1 голос
/ 24 мая 2009

У меня есть список, и мне нужно два раздела в каждом пункте. Мне также нужно, чтобы первый раздел был фиксированной ширины. Как мне его кодировать?

Я пробовал использовать списки определений:

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

    </dl>

... и списки пользователей с диапазоном:

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

    </ul>

Ни сработало. Есть ли канонические способы сделать это?

Ответы [ 6 ]

2 голосов
/ 24 мая 2009

Как сказал Алан, но если вы просто добавите 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>

(возможно, вы хотите использовать класс вместо повторения атрибута стиля для каждого элемента списка)

1 голос
/ 24 мая 2009

Способ, который я придумал, возможно, не каноничен (но только потому, что я не уверен, что существует «канонический» способ его реализации), но он работает:

    <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.

1 голос
/ 24 мая 2009

Используйте 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>
1 голос
/ 24 мая 2009

Ширина не применяется к тегам <span>, поскольку они встроены. Попробуйте заменить тег на <div> или <p> или любым другим элементом блока.

0 голосов
/ 24 мая 2009

Я хотел бы спросить: это для представления табличных данных? Нам внушали мысль, что таблицы HTML - это зло, но для того, чтобы показать таблицу данных, они идеально подходят. Я видел несколько кодеров, которые пытались дублировать функциональность тега <table>, используя <div> s и CSS.

Конечно, если это не так, пожалуйста, продолжайте. : -)

0 голосов
/ 24 мая 2009

попробуйте либо метку для первой части, либо встроенный div

...