Подтвердить что ты не робот

Как отображать элементы списка в виде столбцов?

Я пытаюсь создать свой первый отзывчивый макет. Я хочу отображать элементы списка в вертикальной линии, в зависимости от ширины.

<div style="height:800px;">
    <ul>
       <li>1</li>
       <li>2</li>
       <li>3</li>
       <li>4</li>
       <li>5</li>
       <li>6</li>
       <li>7</li>
    </ul>
</div>
1   5
2   6
3   7
4

Если размер браузера изменяется, я хочу, чтобы он стал

1  4  7
2  5
3  6

Может кто-нибудь мне помочь? Я пытался часами, и я ничего не могу получить. Я пробовал использовать таблицы, но я тоже не могу сделать это.

4b9b3361

Ответ 1

Это можно сделать с помощью столбцов CSS3. Вот пример, HTML:

<ul id = "limheight">
 <li><a href="">Glee is awesome 1</a></li>
 <li><a href="">Glee is awesome 2</a></li>
 <li><a href="">Glee is awesome 3</a></li>
 <li><a href="">Glee is awesome 4</a></li>    
 <li><a href="">Glee is awesome 5</a></li>
 <li><a href="">Glee is awesome 6</a></li>
 <li><a href="">Glee is awesome 7</a></li>
 <li><a href="">Glee is awesome 8</a></li>
 <li><a href="">Glee is awesome 9</a></li>
 <li><a href="">Glee is awesome 10</a></li>
 <li><a href="">Glee is awesome 11</a></li>
 <li><a href="">Glee is awesome 12</a></li>    
 <li><a href="">Glee is awesome 13</a></li>
 <li><a href="">Glee is awesome 14</a></li>
 <li><a href="">Glee is awesome 15</a></li>
 <li><a href="">Glee is awesome 16</a></li>
 <li><a href="">Glee is awesome 17</a></li>    
 <li><a href="">Glee is awesome 18</a></li>
 <li><a href="">Glee is awesome 19</a></li>
 <li><a href="">Glee is awesome 20</a></li>
</ul>

CSS

#limheight {
    height: 300px; /*your fixed height*/
    -webkit-column-count: 3;
       -moz-column-count: 3;
            column-count: 3; /*3 in those rules is just placeholder -- can be anything*/
}
#limheight li {
    display: inline-block; /*necessary*/
}

И небольшая демонстрация: небольшая ссылка.

Надеюсь, что это помогло!

Ответ 2

Если вы посмотрите на следующий пример - он использует столбцы с фиксированной шириной, и я думаю, что это поведенческое поведение.

http://www.vanderlee.com/martijn/demo/column/

Если нижний пример совпадает с верхним, вам не нужен плагин столбца jquery.

ul{margin:0; padding:0;}

#native {
  -webkit-column-width: 150px;
  -moz-column-width: 150px;
  -o-column-width: 150px;
  -ms-column-width: 150px;
  column-width: 150px;
  
  -webkit-column-rule-style: solid;
  -moz-column-rule-style: solid;
  -o-column-rule-style: solid;
  -ms-column-rule-style: solid;
  column-rule-style: solid;
}
<div id="native">
  <ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
    <li>6</li>
    <li>7</li>
    <li>8</li>
    <li>9</li>
    <li>10</li>
    <li>11</li>
    <li>12</li>
    <li>13</li>
    <li>14</li>
    <li>15</li>
    <li>16</li>
    <li>17</li>
    <li>18</li>
    <li>19</li>
  </ul>
</div>

Ответ 3

Спасибо за этот пример, SPRBRN. Это помогло мне. И я могу предложить mixin, который я использовал на основе приведенного выше кода:

//multi-column-list( fixed columns width)
  @mixin multi-column-list($column-width, $column-rule-style) {
  -webkit-column-width: $column-width;
  -moz-column-width: $column-width;
  -o-column-width: $column-width;
  -ms-column-width: $column-width;
  column-width: $column-width;

  -webkit-column-rule-style: $column-rule-style;
  -moz-column-rule-style: $column-rule-style;
  -o-column-rule-style: $column-rule-style;
  -ms-column-rule-style: $column-rule-style;
  column-rule-style: $column-rule-style;
 }

Использование:

   @include multi-column-list(250px, solid);

Ответ 4

Создайте список с таким количеством элементов списка, сколько хотите. Затем приложите список в div, установив style = column-width и style = column-gap, чтобы соответствовать информации в ваших элементах списка. Не устанавливайте столбцы style =. Полностью отзывчивый список, который адаптируется к размеру экрана. Плагинов не требуется.

Ответ 5

Вы можете сделать это с помощью CSS3.

Вот фрагмент кода HTML:

<ul id="listitem_ascolun">
	<li>1</li>
	<li>2</li>
	<li>3</li>
	<li>4</li>    
	<li>5</li>
	<li>6</li>
	<li>7</li>
	<li>8</li>
	<li>9</li>
	<li>10</li>
	<li>11</li>
	<li>12</li>    
</ul>