Несколько столбцов - CSS-хитрости

Anonim

Вот пример простого класса из трех столбцов:

.three-col ( -moz-column-count: 3; -moz-column-gap: 20px; -webkit-column-count: 3; -webkit-column-gap: 20px; )

Из которых вы бы применили такой блок текста:


Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus

Пример

Pellentesque обитатель morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum toror quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, communo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, toror neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus

Обратите внимание, что высота каждого столбца автоматически сбалансирована в соответствии со спецификацией.

Также обратите внимание, что эта демонстрация и образец кода используют префиксы поставщиков moz и webkit, должны работать только в браузерах Gecko (Firefox 1.5+ и др.) И Webkit (Safari 3+, Chrome и др.). Насколько мне известно, встроенной поддержки в Internet Explorer или Opera пока нет.

Все связанные свойства

.three-col ( -moz-column-count: 3; -moz-column-gap: 20px; -webkit-column-count: 3; -webkit-column-gap : 20px; -moz-column-rule-color: #ccc; -moz-column-rule-style: solid; -moz-column-rule-width: 1px; -webkit-column-rule-color: #ccc; -webkit-column-rule-style: solid ; -webkit-column-rule-width: 1px; )

Вы также можете установить column-width(с префиксами), но обычно имеет смысл позволить ему автоматически вычислять это.

Правило («правило», например, линия) разделит пробел посередине. Вы можете использовать те же значения, что и border.

Позаботьтесь о том, чтобы ваши текстовые блоки не были слишком высокими, чем (довольно маленькое) окно браузера, в противном случае это та же проблема, что и текст, который шире окна браузера (прокрутка назад и вперед для чтения = отстой). Также учтитеtext-align: justify;

Резервный JavaScript

Представлено в этой статье A List Apart.