Товаров: 0 (0р.)

Как пользоваться 960 grid system: 960 Grid System — это очень просто

Содержание

960 Grid System: зачем нужны CSS фреймворки

Что-то давно я ничего не писал о CSS, а ведь использовать эту технологию приходится практически постоянно.

Кроме того, последнее время я начинаю замечать, что все чаще использую CSS фреймворки. Поэтому сегодня речь пойдет именно о них. А точнее, об одном из них, под названием 960 Grid System.

Почему именно о нем? Тут все очень просто. Я более-менее плотно работал с двумя фреймворками: Blueprint и 960 grid. При этом, на мой взгляд, разработчикам 960 grid system удалось добиться очень хорошего отношения возможности/размер фреймворка.

Рассмотрим его подробнее.

Начнем с недостатков.

Если вы хоть немного интересовались темой, то, конечно, знаете, что есть много возражений против применении CSS фреймворков как таковых.

Основные возражения такие.

1) Фреймворки увеличивают размер страницы.

2) Загоняют разработчика в определенные рамки.

Например, 960 grid предназначен для верстки страниц с шириной 960рх.

3) Многим не нравятся имена классов вроде «grid-16».

4) Кто-то считает, что нужно самому создавать фреймворк «под себя».

Но давайте посмотрим насколько существенны эти недостатки.

1) Объем файлов действительно увеличивается. Но 960 Grid System состоит из трех файлов, суммарный размер которых — 8 кБ (сжатая версия). Если использовать архивацию размер уменьшается до 1,6кБ.

Вы, конечно, сможете обойтись меньшим количеством кода для конкретной страницы, но разница вряд ли будет больше 1 кБ, т.е. если на вашей страничке есть хотя бы парочка картинок, выигрыш в общем объеме окажется менее 1%.

2) По поводу ограничений. Фреймворк, как и любую библиотеку, имеет смысл использовать в случаях, для которых он разрабатывался. Т.е. если нужна «резиновая» верстка, 960 Grid – не подходящее решение (хотя есть проект Fluid 960 Grid System). Но если в тех. задании сказано, что страница должна иметь фиксированную ширину 960px, то ситуация меняется.

3) Имена классов. На мой взгляд – это вопрос привычки. Цифры в имени означают ширину блока и по ним достаточно просто ориентироваться. Кроме того, никто не запрещает использовать одновременно несколько классов, например,

<div class=”grid_4 sidebar”>…</div>

Класс grid_4 будет использовать фреймворк, sidebar – вашими стилями.

4) Свой фреймворк – это хорошо… если у вас есть время на его разработку и вы уверены, что он получится лучше существующих решений.

Теперь о преимуществах.

1) Время разработки. Оно сокращается и значительно, особенно если у вас есть минимальный опыт работы с фреймворком и вы используете его в подходящей ситуации. Т.е. нужно потратить какое-то время на изучение, но окупается оно очень быстро.

2) Фреймворки содержат «хаки» для наиболее распространенных браузеров. Каждый раз решать одни и те же проблемы с позиционированием элементов в IE очень быстро надоедает 😉

3) Упрощается поддержка. Вам будет легче прочитать свой же код, написанный полгода назад, если вы все время используете одинаковые имена классов.

Примечание. Кстати, если вы интересуетесь темой, очень советую почитать статью «Верстка с помощью Grid«.

А теперь небольшой пример.

Допустим, нам нужно сверстать страницу с таким размещением блоков.

Я сразу покажу решение.

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
<head>
    <title>Test 960 Grid System</title>
    <link rel="stylesheet" href="css/reset.css" />
    <link rel="stylesheet" href="css/text.css" />
    <link rel="stylesheet" href="css/960.css" />
    <style type="text/css">
    p {
        border: solid 1px #eee;
    }
    </style>
</head>
<body>
<div>
    <div><p>Заголовок</p></div>
    <div></div>
    
    <div>
        <div><p>Левый блок №1</p></div>
        <div><p>Левый блок №2</p></div>
    </div>

    <div>
        <div><p>Центральный блок №1</p></div>
        <div><p>Центральный блок №2</p></div>
        <div><p>Центральный блок №3</p></div>
    </div>
    
    <div><p>Правый блок.<br /><br /> Может быть любой высоты.</p></div>
    <div></div>
    
    <div><p>Хвостовик</p></div>
    <div></div>
</div>
</body>
</html>

Как видите, мы обошлись практически минимальным количество тегов

div. Вложенные дивы использовались только для левой и центральной колонок, т.к. они содержат несколько блоков.

Теперь о номерах классов.

Общая ширина макета 960px. Фреймворк позволяет разбить ее на 12, 16 и 24 равных части. В данном случае нам достаточно разбиения на 12 частей. Т.е. класс grid_12 имеет ширину 940px плюс отступы по 10px справа и слева.

Точно также класс grid_4 имеет ширину 960 * 4 / 12 = 320px из которых 20px приходится на отступы.

Если мы поместим подряд три блока с классами grid_1, grid_7 и grid_4, то они займут всю ширину страницы.

Кроме того, есть несколько специальных классов, например, alpha и omega. Они позволяют убрать отступы слева (alpha) и справа (omega) у блока. В данном примере эта возможность используется для того, чтобы убрать отступы у вложенных блоков. Иначе они будут прибавлены к отступам контейнера и, например, расстояние между левой колонкой и центральной будет не 20, а 40px.

Также вы можете использовать класс clear для завершения строки с блоками, а также классы prefix_X, suffix_X, push_X и pull_X для создания различных отступов (вместо X нужно подставить число).

Примечание. Если вы планируете использовать этот (или любой другой CSS фреймворк) я очень советую вам взглянуть на исходные файлы со стилями. Как я уже писал, они совсем небольшие и при наличии минимальных познаний в CSS вы быстро разберетесь что к чему.

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

В заключение хочу провести небольшой опрос.

Голосование закрыто. Результаты:

Используете ли вы CSS фреймворки?

  • Нет, но планирую попробовать — 71%, 898 голосов
  • Да — 21%, 265 голосов
  • Нет и пробовать не собираюсь — 8%, 108 голосов

Всего проголосовало: 1 271

Удачи!

Постовой

Для малого бизнеса бухгалтерские услуги: Москва и область

Как преобразовать сайт 960.gs в HTML с помощью Bootstrap 3



Я создал макет photoshop, используя 960.gs (960 Grid system). Ширина контейнера веб-сайта выровнена по центру на 960 пикселей. Сайт должен быть отзывчивым.

Что мне делать, чтобы преобразовать сайт в HTMl с помощью Bootstrap 3? Мне нужно настроить начальной загрузки перед загрузкой?

html twitter-bootstrap-3 960.gs
Поделиться Источник Yuvaraj P     18 июня 2014 в 07:13

6 ответов


  • CSS плавающие встроенные элементы (960 GS)

    Я как раз проверял код 906.gs css и заметил, что они сделали все плавающие дивы встроенными. http://960.gs/demo.html Просто интересно, какова цель этого is…I я всегда заинтересован в изучении CSS теорий.

  • Как сделать 3 или 4 макета столбцов с системой 960.gs?

    Я использую сеточную систему 960.gs, вариант с 16 столбцами. Я хочу сделать макет из 3 и 4 столбцов. Как к этому подробно подойти с 960.gs? Демонстрация на http://960.gs/demo.html показывает только образцы с 2 столбцами. Или если их больше, то это не то, что мне нужно. Все столбцы должны иметь…



2

1) Получите ваши текущие конфигурации 960 (номер col, желоба и смещения и ширина col).

2) создайте пользовательский набор начальной загрузки. Вам необходимо обновить разделы «Точки останова запросов Media», » Система сетки » и » Размеры контейнеров » с 960 конфигурациями (@grid-столбцы, поля @grid-gutter-width, и @screen-*).

3) Обновите отзывчивые правила (@screen-* полей), в соответствии с вашими требованиями

4) Включите все css файла из загруженной сборки на свою страницу

5) Создайте макет своей страницы в соответствии с руководством по сетке

Поделиться Evgeniy     24 июня 2014 в 09:08



1

Ответы передо мной работают довольно хорошо, но я добавлю еще один: перестаньте хотеть, чтобы все, что вы строите, было идеально по сравнению с тем, что вы высмеяли.

Предполагая, что вы используете макет 12 столбцов в 960.gs, тогда вы золотой, потому что Bootstrap 3 использует макет 12 столбцов. Имеют ли колонны и желоба ту же ширину, что и 960? Скорее всего, нет. Но я могу гарантировать, что экран, который ваши пользователи будут использовать для просмотра веб-сайта, также не будет соответствовать настройкам, которые вы используете в Photoshop.

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

Поэтому вам не стоит беспокоиться, если 960.gs может равняться Bootstrap, потому что реальный мир не будет соответствовать Photoshop. Загрузите Bootstrap, начните кодировать свой веб-сайт и будьте гибки в отношении того, что он не идеально подходит для вашего текущего видения, потому что он никогда не собирался в первую очередь.

Поделиться Sean Ryan     25 июня 2014 в 19:08



1

Как насчет того, чтобы просто добавить внешний div с кадром идентификатора?

<div>
<!-- Your Other Structure -->
</div>

затем в CSS сделайте это,

body, html {
    height: 100%;
    width: 100%;
    min-width: 960px;
}

#frame {
    width: 960px;
    min-width: 960px;
    max-width: 960px;
    margin: 0 auto;
    height: 100%;
}

Поделиться Tushar Srivastava     18 октября 2014 в 20:17



0

Да, вам нужно будет настроить bootstrap перед загрузкой. В частности, вы захотите настроить столбцы сетки и grid-gutter-width в системе сетки (в соответствии с вашими спецификациями) и общую ширину на рабочем столе контейнера в размерах контейнера .

Поделиться Shawn Taylor     24 июня 2014 в 20:19



0

Не совсем уверен, чего вы пытаетесь достичь здесь, например, что @dougajmcdonald сказал, что ваш вопрос недостаточно конкретен.

Увы, мне наскучила работа, поэтому я собираюсь снять здесь несколько ответов.

Я погуглил 960.gs, и это в основном сеточная система. Поэтому, если вы спрашиваете, можно ли сделать ваш макет photoshop с помощью Bootstrap 3, то да, вы можете.

Bootstrap также имеет свою собственную сеточную систему. Самым близким к вашему 960px является класс col-md-* сетки bootstrap. Он обрабатывает их шириной до 990 пикселей и также разбит на 12 столбцов.

Что касается настройки, то это зависит от того, что вам нужно от вашего дизайна.

Поделиться Dominic     24 июня 2014 в 08:48


  • Не может быть окрашен в фон контейнера 960.gs

    Я использую 960.gs (http://960.gs) в качестве фреймворка CSS для своего сайта и пытаюсь раскрасить фон классов .container_12, а не моих классов .grid_12 для дополнительных 10 пикселей, которые я получаю с каждой стороны, давая сетке немного whitespace, чтобы дышать. Я посмотрел на примерный сайт…

  • что делает этот однострочный JS для индексной страницы 960.gs?

    Я пытаюсь принять 960.gs (сеточная система 960 CSS) для моего следующего проекта HTML+AJAX. И лучше всего начать с проверки реализации индексной страницы 960.gs. После осмотра элементов на этой странице Я заметил следующую однострочку в ее головном разделе: Рассмотрим следующий фрагмент:…



0

Вам ничего не нужно делать, так как вы берете свой макет psd и начинаете его кодировать. Как и то, что сказал Шон, предполагая, что вы использовали сетку из 12 столбцов в photoshop, использование Bootstrap 3 не должно быть проблемой. Если у вас есть разделы в psd, которые занимают 3 столбца, это просто переводится в:

<div> ... </div>

md для размеров экрана рабочего стола. Если бы вы также разработали свой мобильный макет, вы бы использовали:

<div>...</div>

… предполагая, что этот раздел будет занимать всю ширину в мобильном телефоне…

Поделиться Angelo Cordon     30 июня 2014 в 01:57


Похожие вопросы:


Текст выливается из Div с помощью 960 gs

Я использую фреймворк 960 gs CSS, и у меня возникли проблемы с текстом, вываливающимся из div. Как заставить текст сделать еще одну строку после того, как он достигнет максимального количества…


Получение 960.gs для работы в IE6-пожалуйста, помогите

Я использую сеточную систему 960.gs для стилизации веб-сайта. Он отлично работает во всех основных браузерах, за исключением IE6, я вижу, что другие сайты прекрасно используют 960.gs, и он отлично…


расширьте верхний / нижний колонтитул bg до края экрана с помощью 960.gs

Я использую таблицы стилей 960.gs для сайта drupal — я хотел бы расширить как верхний, так и Нижний колонтитулы до края веб — страницы, что приведет к чему-то точно такому же, как сайт stack…


CSS плавающие встроенные элементы (960 GS)

Я как раз проверял код 906.gs css и заметил, что они сделали все плавающие дивы встроенными. http://960.gs/demo.html Просто интересно, какова цель этого is…I я всегда заинтересован в изучении CSS…


Как сделать 3 или 4 макета столбцов с системой 960.gs?

Я использую сеточную систему 960.gs, вариант с 16 столбцами. Я хочу сделать макет из 3 и 4 столбцов. Как к этому подробно подойти с 960.gs? Демонстрация на http://960.gs/demo.html показывает только…


Не может быть окрашен в фон контейнера 960.gs

Я использую 960.gs (http://960.gs) в качестве фреймворка CSS для своего сайта и пытаюсь раскрасить фон классов .container_12, а не моих классов .grid_12 для дополнительных 10 пикселей, которые я…


что делает этот однострочный JS для индексной страницы 960.gs?

Я пытаюсь принять 960.gs (сеточная система 960 CSS) для моего следующего проекта HTML+AJAX. И лучше всего начать с проверки реализации индексной страницы 960.gs. После осмотра элементов на этой…


Как разделить стиль и html с помощью Bootstrap и 960.gs

Я начал использовать Bootstrap и очень расстроен! И я также использую rails, поэтому моя философия заключается в том, чтобы организовать веб-объекты как можно больше. Я собираюсь поговорить о…


960.gs фреймворк + нижний колонтитул с нечетным числом членов

у меня возникла проблема с макетом, который я в настоящее время стилизую в CSS с помощью фреймворка 960GS. Страница имеет ширину 960 пикселей, как того требует этот фреймворк, так что это не…


Fixed-Fluid-Fixed макет для 960.gs

Наш веб-сайт системы использует подвесную систему 960.gs и я пытаюсь изменить его на 3 фиксированных столбцов(100 Пикс.)-жидкость(Макс ширина)-исправлено(100 Пикс.) просмотра. К сожалению, все…

Сетка (Grid system) Основы веб-дизайна

Самое важное в веб-дизайне это Grid System. Это основа и фундамент вашего будущего сайта, интерфейса, приложения. 

Без использования сеток ваша работа будет кривая и не гармоничная, это первое, а второе сетки позволяют ускорять процесс разработки сайтов. 

Прежде чем приступить к созданию дизайна сайта, надо обязательно создать в рабочем макете сетку, по которой вы будите ориентироваться. Сегодня сеточными CSS системами пользуется практически каждый разработчик. 

Сетки — это вообще отдельная культура. Есть огромное количество книг, материалов, статей на эту тему. Сетки используются не только при создании сайтов, но и в графическом дизайне.  И я вам рекомендую глубоко и досконально изучить данный вопрос.  Благо в сети огромное количество материалов на эту тему.

Используя сетку, вот так вот легко и просто вы сможете аккуратно позиционировать текст, задавать размеры, выбирать отступы.

А если вы не будете использовать сетку и все делать «на глаз», то получите  кривой результат. Верстальщик получив такой макет, поверьте, будет не очень рад. Глядя на макет, всегда очень просто определить, делал его любитель или профессионал. У хороших дизайнеров никогда не скачут отступы, размеры, шрифты, все сделано аккуратно, ровно. Ниже предоставлен пример работы без сетки, «на глаз».

Кстати, с системой сеток нас познакомили еще в ранней школе. Все помнят тетради в клеточку? В линейку? 

Как видите, без сетки — никуда. Она присутствует даже в школьных тетрадях. И создана для того, чтобы облегчать нам жизнь. 

Особенно в веб-дизайне сетка важна в работе с текстом. На это тоже обращайте пристальное внимание. Иначе макет может быть с виду казаться ровный, но если внимательно рассмотреть типографию, то все криво будет плясать и скакать по всему сайту, что очень быстро расскажет о вашем непрофессионализме и незнании вопроса.  Суть в том, что когда вы работаете в тексте и выбирайте межстрочный интервал (отступ), текст везде должен быть на линии четко, если вы хотите ровный сбалансированный макет. 

Baseline

Есть такое понятие  как «Базовая линия» (англ. baseline, или линия шрифта) — воображаемая прямая линия, проходящая по нижнему краю прямых знаков без учёта свисаний и нижних выносных элементов. В строке символы текста стоят на базовой линии, а нижние выносные элементы текста «свисают» с неё.

Baseline желательно тоже подчинять определенной сетке. Он задает вертикальный ритм. 

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

Какой у вас может возникнуть нюанс?

Для дизайнера вертикальный ритм — это «оптическое понятие», для расчета которого нет точных параметров, поскольку создается он кропотливой проработкой каждого текстового блока, его строк и отступов, размеров. В веб-дизайне все эти тонкости реализовать довольно сложно. Не достаточно просто задавать размеры всех шрифтов под одну высоту строки — это приведет к тому, что в крупных абзацах строки будут слипаться, и буквы будут находить друг на друга,  а в мелких расстояние между  строками будет слишком большое.

 Особенно это плохо смотрится если текст довольно мелкий: 

Как я решаю эту проблему? В таких случаях, я делаю меньше отступ. И подбираю его по схеме, чтобы только  каждая вторая линия стояла ровно на линии сетки.

Тогда отступ в тексте не такой большой и удобно читать и визуально воспринимается приятнее.  Слева пример, когда только каждая вторая линия текста попадает  четко на линию сетки, а справа, где каждая линия текста стоит ровно на сетке.

Но имейте в виду,  что эта не панацея, подходов и правил и разных сеток огромное количество. Я лишь даю базовые подсказки, от которых вы должны отталкиваться. Многие начинающие веб-дизайнеры игнорируют такие элементарные правила как работа с сеткой и на выходе мы получаем кривые, разношерстные и неприятные макеты. Где потом верстальщики хватаются за голову и не знают как нормально все это сделать и по итогу, точно так же на глаз,  делают тяп-ляп.  И тем более когда мы живем в мире адаптивного веб-дизайна, сетки являются чуть ли неотъемлемой частью веб-разработки. 

Ну и для лучшего понимания зачем  нужна сетка и как ее еще используют в веб-дизайне, привожу еще дополнительные примеры на реальный сайтах. Как видите, все везде подчиняется определенной системе. 

Модульная сетка используется типографами, графиками, фотографами и дизайнерами выставок для решения двух- и трехмерных визуальных задач. График и типограф с помощью модуля делают рекламу, проспекты, каталоги, книги, журналы, дизайнер выставок создает концепцию экспозиции, стендов, рекламных дисплеев и так далее. Структурируя при помощи модульной сетки плоскости и пространство, дизайнер получает возможность организовать тексты, фотографии и графические изображения по принципам объективности и функциональности. Сокращается число форматов для изобразительных элементов. Величина иллюстрации определяется в соответствии с ее значением для данной темы. Сокращение визуальных элементов и включение их в модульную систему создает впечатление продуманного единства, прозрачности, ясности, возникает порядок в оформлении. Логично организованный дизайн поддерживает достоверность информации и располагает к ней читателя. Информация с ясно и логически расположенными заголовками, подзаголовками, текстами, иллюстрациями и подписями к ним не только быстрее и легче читается, она лучше понимается и откладывается в памяти. Это научно доказанный факт, и дизайнер должен постоянно держать его в уме. 
Из главы «Для чего нужен модуль». Книга Йозефа Мюллера-Брокманна «Модульные системы в графическом дизайне. Пособие для графиков, типографов и оформителей выставок»

Источник: https://www.artlebedev.ru/izdal/modulnye-sistemy/

Вариантов сеток огромное количество. Именно благодаря ним, журналы, веб-страницы, книги, получаются стильными, красивыми, оригинальными. 

Вы должны четко понимать как вы будите использовать сетку и какие элементы в ней располагать.

С чего же начать?

Конечно, сразу новичкам будет довольно сложно все это понять. Но я предлагаю начать изучения сеток с самого простого. Первое и самое нужное, что понадобиться веб-дизайнеру это сетка 960 grid. Научитесь сначала работать с этой сеткой, практикуйтесь и постепенно изучайте другие виды сеток.

960 grid system

960 grid system — это пожалуй самая распространенная система сеток для веб-дизайна. Более подробную информацию можно узнать на официальном сайте 960 grid и там же скачать исходники сетки. Если очень вкратце, то принцип работы с этой сеткой очень хорошо объясняется в этом видео:

Некорректная ссылка. Попробуйте другую.ОтменаВставить

Заменить видео

Простыми словами, при работе с дизайном используйте вертикальную и горизонтальную сетку. Как я уже говорил, это очень глубокая тема и требует довольно досконального изучения, чтобы хорошо понимать как устроены сетки и как с ними правильно работать. Поэтому очень подробно описывать все процессы работы с сетками в этой главе, я не вижу смысла. Уже написано большое количество прекрасных книг на данную тему, снято обучающих видео, создано полезных статей. Все это надо внимательно изучить, если вы хотите быть настоящим профессионалом. Подробное изучения сеток и какие они бывают, где используются и как, вы можете узнать в ниже предоставленных материалах.

Если говорить совсем просто, то на выходе ваш макет должен иметь вот такой вид: 

Как видите, все четко, ровно, по колонкам. Конечно, если вы смотрели внимательно, то заметили, что кнопки выходят за колонки. Это нормально, такое допустимо, основа блока сделана по сетке, а внутри блока, уже допустимы отклонения. Выше на скрине можете еще увидеть у цитат текст не по колонкам. Это тоже нормально. Сама основа (фон) сделана ровно по колонке, а то что уже внутри этого блока происходит может жить своей жизнью, как ей удобно. Внутри автор добавил для цитаты отступы, дал воздух тексту со всех сторон и цитата выглядит симпатично и хорошо.  И точно так же в футере иконки оплаты выровнены по правому краю, а уже внутри блока, иконки не подчиняются сетке, хотя можно сделать иконки и больше, и подогнать ровно под три колонки, но они будут выглядеть гигантскими. Тут уже надо развивать вкус, чувствовать композицию, соотношения объектов, баланс. Все придет со временем. 

Поэтому вам надо много практики и изучений данного вопроса. 

Итог:

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

1. Для начала создайте горизонтальный ритм. Какая ширина сетки? Сколько колонок?  Какие отступы?  В этом вам помогут генераторы сеток онлайн.  (Modulargrid, gridcalculator и др.)

2. Дальше создайте вертикальный ритм для Baseline. 

Использование сетки при передаче макетов в верстку

После того, как вы создали сетку в макет, и хотите передать исходник ее не стоит удалять из слоев. Оставьте слой сетки активным слоем и чтобы ее было видно. А еще лучше передавать сетку верстальщикам в виде отдельной спецификации. Вы можете приложить к основному jpg макета дополнительный jpg с сеткой. Можно еще прописать на нем основные размеры — например шаг, отступ, ширину колонки, размеры шрифтов. Тогда соответствие вашего макета и верстки станет более точным. 

Опять же в помощь могут прийти генераторы сеток онлайн, которые помогут вам сгенерировать все необходимые данные для верстальщика. 

Не всегда все начинается с сетки

Еще хотел бы добавить важный момент, что при создании дизайна ( в частности если вы разрабатываете еще что-то кроме сайтов и приложений) , не всегда лучше начинать именно с сетки. Для начала лучше начать с бумажного эскиза или наброска композиции, а уже после этого когда вы знаете, что хотите получить, подобрать или построить сетку. Бываеет, так, что например рисуешь дизайн обложки к журналу по сетке, все ровно, красиво, но когда отключаешь сетку, композиция выглядет иначе. Поэтому учитывайте  в первую очередь свое визуальное восприятие.  Если отключая сетку, вы видите, что , что-то не  так, возможно стоит переделать как надо без  сетки, а потом уже подогнать и расчитать новую сетку, которая бы соответстовала вашей правильной композиции и отступам. 

Полезные книги

Хочу еще порекомендовать полезные книги о сетках в графическом дизайне. 

Grid Systems in Graphic Design: A Йозеф Мюллер-Брокманн «Модульные системы в графическом дизайне»

Книга для начинающих графиков, типографов и оформителей выставок.

Эта книга — настоящий рай для перфекционистов. Представляет собой подробное пособие, которое необходимо читать даже тем, кто знает советы о вёрстке наизусть. Книга не просто детально и убедительно доказывает универсальность модульного метода, но и поможет структурировать все знания в систему.

Скачать книгу
Купить книгу на русском языке

The complete guide to CSS grid

Полное руководство по CSS сетке. Отличный материал для дизайнеров и разработчиков. 

Читать онлайн (на английском)

Аллен Хёрлберт — Сетка

Книга Аллена Хёрлберта «Сетка» (аналогично предыдущей), даже на русском.

Скачать книгу

Модульные сетки: Проектирование многополосных изданий

Лаптев, Владимир Владимирович

Скачать книгу

Полезные инструменты

Еще хочу поделиться полезными ресурсами для построения сеток.

Modulargrid


http://modulargrid.org/#app

Генератор модульных сеток. Приложение позволяет задавать Baseline, ширину и высоту модуля, количество модулей, отступы, общую ширину. Можно все это сохранить как PNG паттерн или photoshop паттер или даже маску. Можете поиграться с параметрами и наглядно понять как создается сетка и из каких частей она состоит. 

Gridcalculator


http://gridcalculator.dk/

Более простое приложение. Помогает быстро делать расчет сеток для веб-сайтов и приложений под разные разрешения экранов. 

Gridinator

http://gridinator.com

Удобный инструмент, позволяет генерировать сетку с параметрами pixel widths, em widths, percentage widths. Есть экспорт сетки в CSS, html, image. 

GridDesigner 


http://grid.mindplay.dk

Инструмент для продвинутых дизайнеров. Больше подойдет скорее разработчикам,  так как приложение делает экспорт в CSS только. Есть еще  возможность задать набор параметров для типогрфии.  

Gridlover


https://www.gridlover.net/try

Хорошее приложение, которое поможет создать вертикальный ритм для текста. Но как вы можете заметить, Baseline тут действует иначе.  Это больше вариант CSS вертикального ритма.  Программа при увеличении/уменьшении размера отступов строк автоматически подгоняет размеры шрифтов, чтобы текст не слипался или наоборот не был слишком большим. Программа наглядно поможет вам понять, как это работает в CSS. 

У вас остались вопросы? Или хотите что-то добавить важное к этой главе? Оставьте свой комментарий. 

Grids — Изучение веб-разработки | MDN

Сетки (grids) являются установленным инструментом проектирования и многие современные макеты веб-сайта основаны на регулярной сетке. В этой статье мы рассмотрим дизайн на основе сетки и увидим как CSS можно использовать для создания сеток — как с помощью современных инструментов, так и с помощью новых технологий, которые только начинают становиться доступными в браузерах.
Необходимые навыки:основы HTML(изучите Introduction to HTML), понимание как работает CSS (изучите Introduction to CSS и Styling boxes.)
Задача:Понять основные концепции, лежащие в основе систем компоновки сетки и как реализовать сетку на веб-странице.

Сетка (grid) — это просто набор горизонтальных и вертикальных линий, создающих шаблон, по которому мы можем выстроить элементы дизайна. Они помогают нам создавать проекты, в которых элементы не прыгают или не меняют ширину при переходе от страницы к странице, обеспечивая большую согласованность на наших сайтах.

В сетке обычно будут столбцы (columns), строки (rows), а затем промежутки между каждой строкой и столбцом, обычно называемые желобами (gutters).

[Временная диаграмма; скоро будет заменена лучшей диаграммой.]

Примечание: Может показаться удивительным, если кто-нибудь из фона дизайна, что CSS не имеет встроенной сетки, и вместо этого мы, похоже, используем множество субоптимальных методов для создания сетчатых конструкций. Как вы узнаете в последней части этой статьи, это изменится, однако вам, вероятно, понадобятся существующие методы создания гридов в течение некоторого времени.

Чтобы обеспечить постоянный опыт на вашем сайте или в приложении, основываясь на системе сетки с самого начала, вам не нужно думать о том, насколько широкий элемент имеет отношение к другим элементам. Ваш выбор ограничен «количеством столбцов сетки, которые этот элемент будет охватывать».

Ваша «сеточная система» может быть просто решением, принятым в процессе проектирования, для использования регулярной сетки. Если ваши проекты начнутся в приложении для редактирования графики, например Photoshop, вы можете создать сетку для ссылки во время этого процесса, как описано в  A better Photoshop grid for responsive web design by Elliot Jay Stocks.

Ваша сетевая система также может быть структурой — либо третьей стороной, либо созданной вами только для вашего проекта, — которую вы используете для обеспечения сетки с помощью CSS.

Мы начнём с рассмотрения того, как вы можете создать простую сетку для вашего проекта.

В настоящее время большинство макетов типа grid создаются с использованием поплавков (floats). Если вы прочитали нашу предыдущую статью о поплавках, вы уже видели, как мы можем использовать эту технику для создания раскладки нескольких столбцов, что является сущностью любой сетки, использующей этот метод.

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

В следующих разделах мы рассмотрим, как создать оба. Мы создадим сетку с 12 столбцами — очень общий выбор, который, как видно, очень адаптируется к различным ситуациям, учитывая, что 12 прекрасно делится на 6, 4, 3 и 2.

Простая сетка с фиксированной шириной

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

Начните с создания локальной копии нашего образца simple-grid.html файла, который содержит следующую разметку в своём теле.

<div>
  <div>
    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>
    <div>10</div>
    <div>11</div>
    <div>12</div>
  </div>
  <div>
    <div>13</div>
    <div>14</div>
    <div>15</div>
    <div>16</div>
  </div>
</div>

Цель состоит в том, чтобы превратить это в демонстрационную сетку из двух рядов на двенадцать столбцов сетки (grid) — верхний ряд, демонстрирующий размер отдельных столбцов, второй ряд — некоторые области разного размера в сетке.

В элементе <style> добавьте следующий код, который даёт контейнеру ширину 980 пикселей с отступом с правой стороны 20 пикселей. Это даёт нам 960 пикселей для нашей общей ширины столбца/желоба — в этом случае отступы вычитаются из общей ширины содержимого, потому что мы установили box-sizing в рамку по всем элементам на сайте (см. Changing the box model completely для большего объяснения).

* {
  box-sizing: border-box;
}


body {
  width: 980px;
  margin: 0 auto;
}

.wrapper {
  padding-right: 20px;
}

Теперь используйте контейнер строк, который обёрнут вокруг каждой строки сетки, чтобы очистить одну строку от другой. Добавьте следующее правило ниже предыдущего:

Применение этого клиринга означает, что нам не нужно полностью заполнять каждую строку элементами, составляющими полные двенадцать столбцов. Строки будут разделены и не будут мешать друг другу.

Желоба между колоннами шириной 20 пикселей. Мы создаём эти желоба в качестве поля в левой части каждого столбца, включая первый столбец, чтобы сбалансировать 20 пикселей прокладки в правой части контейнера. Таким образом, у нас есть 12 водосточных желобов — 12 x 20 = 240.

Нам нужно вычесть это из нашей общей ширины 960 пикселей, что даёт нам 720 пикселей для наших столбцов. Если мы разделим это на 12, мы знаем, что каждый столбец должен быть 60 пикселей в ширину. Наш следующий шаг — создать правило для класса .col, плавающее влево, предоставив ему margin-left из 20 пикселей для формирования желоба и width из 60 пикселей. Добавьте нижеследующее правило в CSS:

.col {
  float: left;
  margin-left: 20px;
  width: 60px;
  background: rgb(255, 150, 150);
}

Верхний ряд отдельных столбцов теперь будет аккуратно размещаться в виде сетки.

Примечание: Мы также дали каждому столбцу светло-красный цвет, чтобы вы могли точно видеть, сколько места занимает каждый.

В контейнерах макетов, которые мы хотим разместить более одного столбца, нужно предоставить специальные классы, чтобы скорректировать их значения width до необходимого количества столбцов (плюс желоба между ними). Нам нужно создать дополнительный класс, чтобы контейнеры могли охватывать от 2 до 12 столбцов. Каждая ширина является результатом сложения ширины столбца этого количества столбцов плюс ширины желоба, который всегда будет набирать номер меньше, чем число столбцов.

Добавьте нижеследующую часть вашего CSS:

/ * Ширина двух колонок (120 пикселей) плюс одна ширина желоба (20 пикселей) */
.col.span2 { width: 140px; }
/ * Три ширины столбца (180 пикселей) плюс две ширины желоба (40 пикселей) * /
.col.span3 { width: 220px; }

.col.span4 { width: 300px; }
.col.span5 { width: 380px; }
.col.span6 { width: 460px; }
.col.span7 { width: 540px; }
.col.span8 { width: 620px; }
.col.span9 { width: 700px; }
.col.span10 { width: 780px; }
.col.span11 { width: 860px; }
.col.span12 { width: 940px; }

С помощью этих классов мы можем теперь выкладывать разные столбцы ширины в сетке. Попробуйте сохранить и загрузить страницу в своём браузере, чтобы увидеть эффекты.

Попробуйте изменить классы на своих элементах или даже добавить и удалить некоторые контейнеры, чтобы увидеть, как вы можете изменять макет. Например, вы можете сделать вторую строку следующим образом:

<div>
  <div>13</div>
  <div>14</div>
</div>

Теперь у вас работает сетка, вы можете просто определить строки и количество столбцов в каждой строке, а затем заполнить каждый контейнер своим необходимым контентом. Отлично!

Создание fluid grid

Наша сетка работает красиво, но имеет фиксированную ширину. Нам очень нужна гибкая (жидкая) сетка, которая будет расти и сокращаться с доступным пространством в браузере viewport. Для этого мы можем использовать опорные пиксельные ширины и превратить их в проценты

Уравнение, которое превращает фиксированную ширину в гибкую, основанную на процентах, выглядит следующим образом.

target / context = result

Для нашей ширины столбца наша целевая ширина составляет 60 пикселей, а наш контекст  960 пикселей. Для расчёта процента мы можем использовать следующее.

60 / 960 = 0.0625

Затем мы перемещаем десятичные точки на 2 места, давая нам процент от 6,25%. Таким образом, в нашем CSS мы можем заменить ширину столбца 60 пикселей на 6,25%.

Мы должны сделать то же самое с нашей шириной желоба:

20 / 960 = 0.02083333333

Поэтому нам нужно заменить 20 пикселей margin-left на наше правило .col  20 пикселей padding-right на .wrapper с 2.08333333%.

Обновление нашей сетки

Чтобы начать работу в этом разделе, создайте новую копию предыдущей страницы примера или создайте локальную копию нашего кода simple-grid-finished.html, который будет использоваться в качестве отправной точки.

Обновите второе правило CSS (с помощью селектора .wrapper) следующим образом:

body {
  width: 90%;
  max-width: 980px;
  margin: 0 auto;
}

.wrapper {
  padding-right: 2.08333333%;
}

Мы не только дали нам процент width, мы также добавили свойство max-width, чтобы остановить распространение макета.

Затем обновите четвёртое правило CSS (с селектором .col) следующим образом:

.col {
  float: left;
  margin-left: 2.08333333%;
  width: 6.25%;
  background: rgb(255, 150, 150);
}

Теперь идёт немного более трудоёмкая часть — нам нужно обновить все наши правила .col.span, чтобы использовать проценты, а не ширину пикселей. Это занимает немного времени с калькулятором; чтобы сэкономить вам немного усилий, мы сделали это для вас ниже.

Обновите нижний блок правил CSS следующим образом:


.col.span2 { width: 14.58333333%; }

.col.span3 { width: 22.91666666%; }

.col.span4 { width: 31.24999999%; }
.col.span5 { width: 39.58333332%; }
.col.span6 { width: 47.91666665%; }
.col.span7 { width: 56.24999998%; }
.col.span8 { width: 64.58333331%; }
.col.span9 { width: 72.91666664%; }
.col.span10 { width: 81.24999997%; }
.col.span11 { width: 89.5833333%; }
.col.span12 { width: 97.91666663%; }

Теперь сохраните свой код, загрузите его в браузере и попробуйте изменить ширину видового экрана — вы должны увидеть, что ширины столбцов хорошо меняются. Отлично!

Более простые вычисления с использованием функции calc()

Вы можете использовать функцию calc () для выполнения математики прямо внутри вашего CSS — это позволяет вставлять простые математические уравнения в ваши значения CSS, чтобы рассчитать, какое значение должно быть. Это особенно полезно, когда необходимо выполнить сложную математику и вы даже можете сделать расчёт, который использует разные единицы, например «Я хочу, чтобы высота этого элемента всегда была на 100% от высоты родителя, минус 50 пикселей». См. этот пример из учебника API MediaRecorder.

В любом случае, вернёмся к нашим сетям! Любой столбец, который охватывает более одного столбца нашей сетки, имеет общую ширину 6,25%, умноженную на количество столбцов, спаренных плюс 2.08333333%, умноженное на количество желобов (которые всегда будут числом столбцов минус 1). Функция calc () позволяет нам делать это вычисление прямо внутри значения ширины, поэтому для любого элемента, охватывающего 4 столбца, мы можем это сделать, например:

.col.span4 {
  width: calc((6.25%*4) + (2.08333333%*3));
}

Попробуйте заменить нижний блок правил следующим, а затем перезагрузите его в браузере, чтобы узнать, получаете ли вы тот же результат:

.col.span2 { width: calc((6.25%*2) + 2.08333333%); }
.col.span3 { width: calc((6.25%*3) + (2.08333333%*2)); }
.col.span4 { width: calc((6.25%*4) + (2.08333333%*3)); }
.col.span5 { width: calc((6.25%*5) + (2.08333333%*4)); }
.col.span6 { width: calc((6.25%*6) + (2.08333333%*5)); }
.col.span7 { width: calc((6.25%*7) + (2.08333333%*6)); }
.col.span8 { width: calc((6.25%*8) + (2.08333333%*7)); }
.col.span9 { width: calc((6.25%*9) + (2.08333333%*8)); }
.col.span10 { width: calc((6.25%*10) + (2.08333333%*9)); }
.col.span11 { width: calc((6.25%*11) + (2.08333333%*10)); }
.col.span12 { width: calc((6.25%*12) + (2.08333333%*11)); }

Примечание: Если вы не можете заставить это работать, возможно, это связано с тем, что ваш браузер не поддерживает функцию calc (), хотя он довольно хорошо поддерживается в браузерах — ещё в IE9.

Семантические и «несемантические» сетчатые системы

Добавление классов в вашу разметку для определения макета означает, что ваш контент и разметка привязаны к его визуальному представлению. Иногда вы слышите это использование классов CSS, описанных как «несемантические», — описывая, как выглядит контент, а не семантическое использование классов, описывающих контент. Это относится к классам span2, span3 и т. Д.

Это не единственный подход. Вместо этого вы можете выбрать свою сетку, а затем добавить информацию о размерах в правила для существующих семантических классов. Например, если у вас есть <div> с классом content в нем, который вы хотите разбить на 8 столбцов, вы можете скопировать по ширине из класса span8, предоставив вам следующее правило:

.content {
  width: calc((6.25%*8) + (2.08333333%*7));
}

Примечание: Если вы использовали препроцессор, такой как Sass, вы могли бы создать простой mixin, чтобы вставить это значение для вас.

Включение офсетных контейнеров в нашей сетке

Сетка, которую мы создали, работает хорошо, пока мы хотим запустить все контейнеры заподлицо с левой стороны сетки. Если бы мы хотели оставить пустое пространство столбца перед первым контейнером — или между контейнерами — нам нужно было бы создать класс смещения, чтобы добавить левое поле на наш сайт, чтобы визуально визуализировать его по сетке. Больше математики!

Давайте попробуем это.

Начните с предыдущего кода или используйте наш файл fluid-grid.html в качестве отправной точки.

Давайте создадим класс в нашем CSS, который будет смещать элемент контейнера на одну ширину столбца. Добавьте нижеследующую часть вашего CSS:

.offset-by-one {
  margin-left: calc(6.25% + (2.08333333%*2));
}

Или если вы предпочитаете самостоятельно рассчитать проценты, используйте это:

.offset-by-one {
  margin-left: 10.41666666%;
}

Теперь вы можете добавить этот класс в любой контейнер, в котором вы хотите оставить пустое пространство с одним столбцом в левой части окна. Например, если у вас есть это в вашем HTML:

<div>14</div>

Попробуйте заменить его на

<div>14</div>

Примечание: Обратите внимание, что вам необходимо уменьшить количество столбцов, чтобы освободить место для смещения!

Попытайтесь загрузить и обновить, чтобы увидеть разницу или посмотрите наш пример fluid-grid-offset.html (см. также «live»). Готовый пример должен выглядеть так:

Примечание: В качестве дополнительного упражнения вы можете реализовать класс «смещение на два»?

Ограничения с плавающей сеткой

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

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

Самое большое ограничение этой системы состоит в том, что она по существу одномерна. Мы имеем дело со столбцами и охватываем элементы по столбцам, но не по строкам. С помощью этих старых методов компоновки очень сложно контролировать высоту элементов без явной установки высоты, и это тоже очень негибкий подход — он работает только, если вы можете гарантировать, что ваш контент будет определённой высоты.

Если вы прочтёте нашу предыдущую статью о flexbox, вы можете подумать, что flexbox — идеальное решение для создания сетчатой системы. В настоящее время доступно множество систем gridbox на основе flexbox и flexbox может решить многие из проблем, которые мы уже обнаружили при создании нашей сетки выше.

Однако flexbox никогда не разрабатывался как сетчатая система и создаёт новый набор проблем при использовании в качестве одного. В качестве простого примера мы можем использовать тот же пример разметки, который мы использовали выше, и использовать следующий CSS для стилей классов-оболочек (wrapper), row и col классов:

body {
  width: 90%;
  max-width: 980px;
  margin: 0 auto;
}

.wrapper {
  padding-right: 2.08333333%;
}


.row {
  display: flex;
}

.col {
  margin-left: 2.08333333%;
  margin-bottom: 1em;
  width: 6.25%;
  flex: 1 1 auto;
  background: rgb(255,150,150);
}

Вы можете попробовать сделать эти замены в своём собственном примере или посмотреть на наш пример кода flexbox-grid.html (см. также он работает в режиме реального времени).

Здесь мы превращаем каждую строку в гибкий контейнер. С сеткой на основе flexbox нам все ещё нужны строки, чтобы мы могли иметь элементы, которые составляют менее 100%. Мы установили этот контейнер для display: flex.

На .col мы устанавливаем первое значение свойства flex (flex-grow) до 1, чтобы наши объекты могли расти, второе значение ( flex-shrink ) до 1, поэтому элементы могут сокращаться, а третье значение ( flex-basis ) — auto. Поскольку наш элемент имеет набор width, auto будет использовать эту ширину в качестве базового значения flex (flex-basis).

В верхней строке мы получаем двенадцать аккуратных коробок на сетке, и они растут и сжимаются одинаково, когда мы меняем ширину окна просмотра. Однако на следующей строке у нас есть только четыре элемента, и они также растут и сокращаются с 60px. Только с четырьмя из них они могут расти намного больше, чем элементы в строке выше, в результате они все занимают одну и ту же ширину во второй строке.

Чтобы исправить это, нам всё равно нужно включить наши классы span, чтобы обеспечить ширину, которая заменит значение, используемое flex-basis для этого элемента.

Они также не уважают сетку, используемую выше, потому что они ничего не знают об этом.

Flexbox является одномерным по дизайну. Он имеет дело с одним измерением — со строкой или столбцом. Мы не можем создать строгую сетку для столбцов и строк, что означает, что если мы будем использовать flexbox для нашей сетки, нам всё равно нужно рассчитать проценты, как для плавающего макета.

В вашем проекте вы всё равно можете использовать сетку flexbox из-за дополнительных возможностей выравнивания и распределения пространства. Flexbox обеспечивает надплавки. Однако вам следует помнить, что вы все ещё используете инструмент для чего-то другого, кроме того, для чего он предназначен. Таким образом, вы можете почувствовать, что он заставляет вас прыгать через дополнительные обручи, чтобы получить конечный результат, который вы хотите.

Теперь, когда мы понимаем математику за нашими расчётами в сетке, мы находимся в хорошем месте, чтобы взглянуть на некоторые из сторонних сетевых систем, которые используются совместно. Если вы ищете «CSS Grid framework» в Интернете, вы найдёте огромный список вариантов на выбор. В популярных структурах, таких как Bootstrap и Foundation, есть сетка. Существуют также автономные сетчатые системы, разработанные с использованием CSS или с использованием препроцессоров.

Давайте рассмотрим одну из этих автономных систем, поскольку она демонстрирует общие методы работы с сеткой. Сетка, которую мы будем использовать, является частью Skeleton, простой CSS-структуры.

Для начала посетите веб-сайт Skeleton и выберите «Загрузить», чтобы загрузить ZIP-файл. Разархивируйте это и скопируйте файлы skeleton.css и normalize.css в новый каталог.

Сделайте копию нашего файла html-skeleton.html и сохраните его в том же каталоге, что и скелет, и нормализовать CSS.

Включите скелет и нормализуйте CSS на странице HTML, добавив следующее в голову:

<link href="normalize.css" rel="stylesheet">
<link href="skeleton.css" rel="stylesheet">

Скелет включает в себя больше, чем сетку — он также содержит CSS для типографики и других элементов страницы, которые вы можете использовать в качестве отправной точки. На данный момент мы оставим их по умолчанию, но именно эта сетка нас действительно интересует.

Примечание: Нормализация — очень полезная небольшая библиотека CSS, написанная Николасом Галлахером, которая автоматически делает некоторые полезные основные исправления макета и делает стиль элементов по умолчанию более согласованным в разных браузерах.

Мы будем использовать аналогичный HTML для нашего предыдущего примера. Добавьте в свой HTML-код следующее:

<div>
  <div>
    <div>1</div>
    <div>2</div>
    <div>3</div>
    <div>4</div>
    <div>5</div>
    <div>6</div>
    <div>7</div>
    <div>8</div>
    <div>9</div>
    <div>10</div>
    <div>11</div>
    <div>12</div>
  </div>
  <div>
    <div>13</div>
    <div>14</div>
    <div>15</div>
    <div>16</div>
  </div>
</div>


Чтобы начать использовать Skeleton, нам нужно предоставить оболочку <div> класс container — это уже включено в наш HTML. Это центрирует контент с максимальной шириной 960 пикселей. Вы можете видеть, как теперь коробки не становятся шире, чем 960 пикселей.

Вы можете посмотреть в файле skeleton.css, чтобы увидеть CSS, который используется, когда мы применяем этот класс. <div> центрируется с использованием auto левого и правого полей, а отступы в 20 пикселей применяются слева и справа. Скелет также устанавливает свойство box-sizing в border-box, как мы делали это раньше, поэтому дополнение и границы этого элемента будут включены в общую ширину.

.container {
  position: relative;
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

Элементы могут быть только частью сетки, если они находятся внутри строки, так как в нашем предыдущем примере нам нужен дополнительный <div> или другой элемент с классом строки (row), вложенным между content <div> и нашим контейнером фактического содержимого <div>. Мы уже это сделали.

Теперь давайте выложим контейнеры. Скелет основан на сетке из 12 столбцов. В верхних строках нужны классы из one column, чтобы они охватывали один столбец.

Добавьте их сейчас, как показано в следующем фрагменте:

<div>
  <div>
    <div>1</div>
    <div>2</div>
    <div>3</div>
    /* and so on */
  </div>
</div>

Затем дайте контейнеры во втором классе классов, объясняющие количество столбцов, которые они должны охватывать, например:

<div>
  <div>13</div>
  <div>14</div>
  <div>15</div>
  <div>16</div>
</div>

Попробуйте сохранить свой HTML-файл и загрузить его в свой браузер, чтобы увидеть эффект.

Если вы посмотрите в файле skeleton.css, вы увидите, как это работает. Например, у Skeleton определены следующие элементы стиля с добавленными к ним классами «три столбца».

.three.columns { width: 22%; }

Весь Skeleton (или любая другая структура сетки) выполняет настройку предопределённых классов, которые вы можете использовать, добавив их в свою разметку. Это точно так же, как если бы вы сами делали расчёт этих процентов.

Как вы можете видеть, нам нужно написать очень мало CSS при использовании Skeleton. Он касается всех плавающих для нас, когда мы добавляем классы в нашу разметку. Именно эта способность нести ответственность за компоновку над чем-то ещё, что делает использование рамки для сетчатой системы неотразимым выбором!

Skeleton — это более простая сетка, чем некоторые из структур, с которыми вы можете столкнуться. Сетки в больших рамках, таких как Bootstrap и Foundation, предлагают больше функциональности и дополнительные точки останова для различной ширины экрана. Тем не менее, все они работают аналогичным образом — добавив определённые классы в свою разметку, вы можете контролировать, как элемент выложен с использованием предопределённой сетки.

В начале этой статьи мы сказали, что CSS ранее не имел реальной системы для создания макетов сетки, но это изменится. Хотя мы ещё не можем использовать встроенную сетевую систему CSS, в следующем году мы увидим поддержку браузера для модуля компоновки сетки CSS (CSS Grid Layout Module).

В настоящее время вы можете использовать только те методы, которые мы покажем вам в браузерах, которые реализуют макет сетки CSS «за флагом» — это означает, что он в настоящее время реализован, но в экспериментальном состоянии, которое вам нужно включить.

В Firefox, например, вам нужно перейти к URL-адресу about: config, выполнить поиск по предпочтению layout.css.grid.enabled и дважды щёлкнуть его, чтобы включить CSS-сетки. Вы можете узнать, как использовать его в других браузерах, посетив Grid by Example.

Мы рассмотрели структуру Скелетной сетки выше — как и другие сторонние решётки и даже ручные сетки, для этого требуется добавить <div> для формирования строк, а затем указать количество столбцов, которые будут охватывать элементы в этих рядах.

С помощью CSS Grid Layout вы можете полностью указать свою сетку в CSS, не добавляя эти вспомогательные классы в разметку вообще. Давайте рассмотрим наш простой пример и посмотрим, как мы будем создавать тот же макет с помощью CSS Grid Layout.

Создание собственной сетки

Сначала начните с создания локальной копии файла css-grid.html. Он содержит следующую разметку:

<div>
  <div>1</div>
  <div>2</div>
  <div>3</div>
  <div>4</div>
  <div>5</div>
  <div>6</div>
  <div>7</div>
  <div>8</div>
  <div>9</div>
  <div>10</div>
  <div>11</div>
  <div>12</div>
  <div>13</div>
  <div>14</div>
  <div>15</div>
  <div>16</div>
</div>

На этот раз у нас есть родительский <div> с классом обёртки (wrapper), а затем все дочерние элементы просто появляются непосредственно внутри обёртки — никаких элементов строки. Мы добавили класс к элементам, которые должны охватывать более одного столбца.

Теперь добавьте следующее в элемент <style>:

.wrapper {
  width: 90%;
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-gap: 20px;
}

.col {
  background: rgb(255,150,150);
}

Здесь мы устанавливаем правило .wrapper, поэтому оно составляет 90% от ширины тела, с центром и имеет max-width 960px.

Теперь для свойств сетки CSS. Мы можем объявить сетку, используя значение grid свойства display, установить жёлоб с свойством grid-gap (en-US), а затем создать сетку из 12 столбцов равной ширине, используя grid-template-columns, новую функцию repeat() и новую единицу, определённую для макета сетки — блок fr.

Блок fr представляет собой блок фракции — он описывает долю доступного пространства в контейнере сетки. Если все столбцы равны 1fr, каждый из них занимает равное количество места. Это устраняет необходимость вычислять проценты для создания гибкой сетки.

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

Чтобы создать контейнеры, которые охватывают несколько треков столбцов в сетке, мы можем использовать свойство grid-column (en-US). Чтобы охватить 6 столбцов, например:

.span6 {
  grid-column: auto / span 6;
}

И для span 3:

.span3 {
  grid-column: auto / span 3;
}

Значение перед косой чертой — это начальная строка — в этом случае мы явно не устанавливаем это и не позволяем браузеру размещать элемент на следующей доступной строке. Затем мы можем установить его на 6, 3 или сколько угодно строк.

Добавьте нижеследующую часть вашего CSS:

.span2 { grid-column: auto / span 2;}
.span3 { grid-column: auto / span 3;}
.span4 { grid-column: auto / span 4;}
.span5 { grid-column: auto / span 5;}
.span6 { grid-column: auto / span 6;}
.span7 { grid-column: auto / span 7;}
.span8 { grid-column: auto / span 8;}
.span9 { grid-column: auto / span 9;}
.span10 { grid-column: auto / span 10;}
.span11 { grid-column: auto / span 11;}
.span12 { grid-column: auto / span 12;}

Попробуйте сохранить и обновить, и вы увидите, что контейнеры охватывают несколько столбцов, если это необходимо. Круто!

Сетки CSS являются двумерными, так как макет растёт и сжимается, элементы остаются выровненными по горизонтали и по вертикали.

Вы можете проверить это, заменив последние 4 col <div> s следующим:

<div>13some<br>content</div>
<div>14this<br>is<br>more<br>content</div>
<div>15this<br>is<br>less</div>
<div>16</div>

Здесь мы намеренно добавили некоторые фрагменты строки (<br>), чтобы заставить некоторые из столбцов стать выше других. Если вы попытаетесь сохранить и обновить, вы увидите, что столбцы регулируют их высоту, как самый высокий контейнер, поэтому все остаётся аккуратным.

Окончательный макет выглядит так:

Другие полезные функции сетки CSS

С сетками CSS нам не нужно толкать вещи вдоль полей, чтобы их компенсировать. Попробуйте внести эти изменения в свой CSS:

.content {
  grid-column: 2 / 8;
}
<div>16</div>

Контейнер 16 теперь будет охватывать столбцы с 2 по 8, в следующей доступной строке, где он может поместиться.

Мы можем так же легко группировать строки так же, как и столбцы:

.content {
  grid-column: 2 / 8;
  grid-row: 3 / 5;
}

Контейнер 16 теперь будет охватывать строки с 3 по 5, а также столбцы с 2 по 8.

Нам также не нужно использовать маржу для фальшивых желобов или явно рассчитать их ширину — сетка CSS имеет эту функциональность, встроенную прямо в свойство grid-gap.

Мы просто касаемся поверхности того, что возможно с помощью CSS Grid Layout, но главное, что нужно понять в контексте этой статьи, это то, что вам не нужно создавать сетку с сеткой — она одна. Вы можете написать CSS, который помещает элемент непосредственно в предопределённую сетку. Это первый раз, когда это было возможно с помощью CSS и это улучшится, когда поддержка браузера закрепится.

Активное обучение: Напишите свою собственную простую сетку

В макете «Введение в CSS» мы включили раздел о CSS-таблицах, который включал простой пример формы (см. Пример css-tables-example.html live и исходный код). Мы хотели бы, чтобы вы взяли копию этого примера и выполните следующие действия:

  1. Удалите элементы <div> внутри <form> — вам больше не нужны эти данные, поскольку CSS-сетки могут обрабатывать размещение содержимого по строкам и столбцам для вас.
  2. Используйте свойства сетки CSS, чтобы создать макет для вашей формы как можно ближе к оригиналу. Вам нужно будет установить ширину на содержащем элементе и подумать о том, как установить пробелы в столбцах, а также пробелы в строке.

Примечание: Сначала выполните это и если вы действительно застряли, вы можете проверить свой код на примере css-tables-as-grid.html. Не обманывайте — сначала попробуйте упражнение!

Прочитав эту статью, вы должны теперь понять, как grid-схемы и grid-структуры работают в CSS. Вы также заглянули в будущее сетки CSS и теперь должны понимать, что используемые нами grid-сетки — это, по сути, стоп-решение, пока у нас не будет широко распространённого способа достижения этого в CSS.

Модульные сетки в веб-дизайне

«Сетка — это система помощи, но она не является гарантией, а всего лишь имеет ряд возможных применений, и каждый дизайнер сам может искать решение, соответствующуе его индивидуальному стилю.  Но надо научиться использовать сетку. Это искусство, которое требует практики «.

Йозеф Мюллер-Брокман

 

По сути, само использование сетки  связано с одним из старейших и самых основных принципов дизайна — выравнивания. Наш мозг хочет всё упрощать и делать более понятным. Вот почему мы стараемся навести порядок в вещах, которые кажутся хаотичными.

Естественно, чем быстрее мы всё правильно организуем, тем быстрее наш мозг сможет определить модель и двигаться дальше. Сетки настолько упорядоченны, что почти не требуют интерпретации с нашей стороны.

Рассмотрим два макеты страниц представлена ​​на рисунке ниже:

Хотя оба эти изображения — всего лишь несколько прямоугольников, набор в верхней части кажется принципиально лучше чем в нижней. Мы можем мгновенно распознать модель, принять её и двигаться дальше. Изображение внизу же вызывает визуальный дискомфорт, так как не имеет четкой картины, порядка, или цели и выглядит как случайный набор форм.

Следует отметить, что неорганизованность также ​​может быть и красивой. В природе, например, нет чётких линий. Сетки выглядят холодными и жесткими, но помните, что они являются очень эффективным и действенным методом не позволить вашему воображению увязнуть в структурах.

Взгляните на некоторые из самых популярных сайтов с первоклассным дизайном. Скорее всего, они использовали сетку. Сетки позволяют стабилизировать  структуру веб-страницы и предоставляют дизайнеру логический шаблон для создания сайта.

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

Проще говоря, сетка — это разделение макета вертикальными и / или горизонтальных направляющими включая поля, пространство и некоторое количество столбцов для того, чтобы заложить основу для организации контента.

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

Начиная изучать новые навыки в той или иной сфере, вы должны сначала следовать рекомендациям. Обучение основам гарантирует то, что вы сможете применять принципы эффективно. То есть, сначала — теория, а затем — практика.

Стоит отметить, что существует два способа создания сетки шаблона:

Способ №1: Создайте свою собственную сетку

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

Вы можете разделить пустой документ математически, создавая четное или нечетное число столбцов для работы. Ваша сеть может быть сложной или простой, вы можете использовать правила третей или золотого сечения,  как вам больше нравится.

Возможно, в этом вам помогут следующие статьи:

Вот несколько примеров сетей, созданных в Photoshop с помощью направляющих (View> New Guide):

Плагины для создания сеток в Фотошопе

1. GuideGuide — полезный плагин для дизайнеров, которые вручную чертят сетки.  Есть версии для Photoshop CS4 и CS5+. Подробнее читайте здесь.

2. Modular Grid Pattern

3.  GridMaker 2

4. Скрипт для создания сетки из шейпов в Фотошопе

Способ №2: Скачайте готовый шаблон сетки

В интернете есть много готовых шаблонов сеток, которые вы можете использовать при  создании сайта. Они помогают существенно сэкономить время. Давайте рассмотрим некоторые из них.

Сетки фиксированной ширины

1. 960.gs — пожалуй, самый популярный инструмент для создания сеток. О том, как пользоваться этим фреймворком читайте здесь.

2. Сеточные шаблоны для Photoshop

3.  Modular Grid Pattern (о том, как использовать этот сервис,  читайте  здесь )

4. Grid Designer

5. Grid System Generator -генератор таких популярных сеток, как 960.gs, Golden Grid, 1Kb Grid, Simple Grid/ установите нужные параметры и нажмите «GENERATE».

6. Grid Calculator — калькулятор, который позволяет рассчитать параметры сетки.

 

Сетки для резиновых/ адаптивных сайтов

Адаптивный веб-дизайн пользуется огромной популярностью на сегодняшний день. Основным из его принципов считается использование резиновой сетки. Более подробно о них вы можете прочитать здесь, а мне бы хотелось немного дополнить эту подборку и добавить ещё несколько ресурсов.

1. Gridpak — генератор адаптивной сетки

2. Fluid grid calculator — сервис, который позволяет создать резиновую сетки. Введите параметры и получите готовый код.

3. Fluid Baseline Grid — резиновая сетка с базовой линией

Учимся работать с сеткой

Для закрепления материала рекомендуем серию уроков на английском языке по созданию сайта, который построен на сетке

Смотрите демонстрацию

Часть1 — рисуем макет в  Фотошопе

Часть2 — верстка

Часть3 — натягиваем на Wordpress

Полезные статьи и ресурсы:

 

При написании статьи использованы материалы из :

CSS-фреймворк. Использовать или нет? | Master-web


Здравствуйте!
Сегодня мне хотелось бы написать в новом стиле. Не на новые темы, а именно в новом стиле. Этот пост, в отличии от всех предыдущих, будет не столько информативным, сколько построенным в рамках размышления с намеком на диалог. Разговор пойдет о CSS-фреймфорках. Вернее не о самих фреймворках, а об их использовании.

Собственно, начал я этот разговор потому, что мне на глаза попало интересное решение в виде Fluid 960 Grid System — CSS-фреймворк, который был разработан Стивеном Бау на основании известного и популярного фреймфорка 960.gs. Решение предложенное Стивеном дает возможность быстро создать базовую 16 или 12-колоночную разметку с красивыми и популярными js-эфектами, реализовать которые можно с использованием библиотек jQuery или Mootools по выбору разработчика. Кроме этого, как можно судить по названию, изначально фреймворк ориентирован на «резиновую» верстку, хотя при желании можно использовать и фиксированную верстку, но тогда фреймворк мало чем отличается от своего родителя 960.gs.

Почему именно 960.gs? Наверное потому, что я уже давно использую в своих макетах дизайна сайта базовую 12-ти колоночную сетку именно оптимизированную под 960px. Вот именно поэтому мне приглянулось «творение» Стивена. Но есть моменты, которые не совсем мне понравились в этом фрейворке. Например, мне не понравилось то как реализована типографика, несколько смешаны стили разметки и типографики, что поначалу вносит некий сумбур в верстку. Хотя, если изучить код более детально, то становится понятна логика разработчика, вернее логика разработчиков 960.gs, стили разделены непосредственно по функциональным элементам, что в последствии может помочь разработчику. Еще один момент, который смутил меня в типографике — это прописанные в пикселях параметры размеров шрифтов и отступов. И хотя в последствии в функциональных блоках уже используется размер шрифтов в em, который просчитывается от базового, я все таки остаюсь приверженцем простоты и единообразия в типографике «без лишних поворотов».

Но не смотря на эти небольшие недостатки CSS-фреймворк от Стивена Бау Fluid 960 Grid System на основании известного и популярного фреймфорка 960.gs я считаю очень удачной разработкой. Лично для себя я принял решение, что, по крайней мере сетку, я обязательно интегрирую в свой собственный фреймворк, который использую в верстке, и в скором времени думаю представлю на ваш суд собственную сборку. Возможно, для кого-то она окажется полезной. А для меня будет очень полезным узнать какие CSS-фреймворки и наработки вы используете в верстке. Приглашую всех к обсуждениям в комментариях.

P.S. Мысли о разном…

Кто знает что такое керамзит? Ладно, а кто знает что такое гравий? Так вот керамзит на сегодня есть наиболее популярным сырьем-основой для гравия. Вот такой вот я строитель 🙂

Ну и закончим все таки тематическим сообщением о том, как создать свой сайт самостоятельно. А создать свой сайт просто — надо просто захотеть 🙂 Успехов!

5 популярных CSS фреймворков

CSS фреймворки становятся все популярнее и популярнее последнее время, они позволяют разработчикам быстро создавать прототипы проектов. Идея css фреймворков заключается в том чтоб сделать всю нудную и повторяющуюся работу, повторяющуюся на каждом сайте снова и снова, что позволяет ускорить процесс разработки. 

Основные черты хорошего css фреймворка:

  • значительное ускорение времени разработки
  • малые размеры
  • хорошая документация

Сейчас я представлю небольшой обзор 5 самых популярных css фреймворков, найденную для них демонстрацию и учебники. Вы обязательно найдете здесь полезную информацию, которая позволит сэкономить время и упростить процесс разработки.

960 Grid System представляет собой попытку рационализировать рабочий процесс веб-разработки, используя сеточную модель верстки, основанную на ширине 960 пикселей. Есть два варианта: 12 и 16 колонн, которые могут быть использованы отдельно или в вместе. Файл фреймворка занимает всего 3,6 Кб в сжатом виде. 

Смотреть демо

Учебники, объясняющие, как использовать 960 CSS Framework

Тут детально рассмотрен 960 CSS Framework. Приведены плюсы и минусы его использования. Также есть инструкции где шаг за шагом рассказано про создание «12 колоночной» схемы с простым заголовком и двумя столбцами структуры. Наиболее важный совет состоит в следующем: необходимо присвоить класс, каждому диву. Соглашения об именовании требуют, что имя класса должно начинается с «grid_» и заканчиваться числом  необходимых столбцов.

Тут описаны основы этого фреймворка, чтобы вы могли начать работу с 960 довольно быстро. Основные методы описанные здесь включают: не редактировать 960.css, загрузка сети, контейнеры, сетки / колонки, поля и стилизация. Другой пост того же автора, где он решает некоторые проблемы с которыми он столкнулся при работе с этим фреймворком.

Fluid 960 Grid System шаблоны были построены на основе 960 Grid System с использованием эффектов из библиотеки Mootools JavaScript.

Blueprint это CSS framework, целью которого является сократить ваше время на написание CSS кода. Он дает вам прочную CSS основу для создания вашего проекта с помощью простой в использовании сетки, типографики, красивых форм и, даже, стилей для печати.Одна из его основных функций выполняет сброс стилей браузера по умолчанию, предлагает методы для использования настраиваемой сетки макета.

Доступно несколько плагинов Blueprint, которые могут заменить аспекты структуры или добавить новые стили для вашего использования. 

Смотреть демо

Учебники, объясняющие, как использовать Blueprint CSS Framework

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

Этот инструмент поможет вам генерировать более гибкие версии grid.css и compressed.css и файл grid.png изображения для использования в качестве фонового изображения в процессе разработки, очень удобно для того, чтобы все линии отображались должным образом. Предпочитаете вы 8, 10,16 или 24 столбцов в дизайне, этот генератор позволяет использовать гибкость Blueprint. 

JQuery UI включает в себя надежный CSS Framework предназначенный для создания пользовательских виджетов JQuery. Структура включает в себя классы, которые охватывают широкий спектр общих потребностей в создании пользовательского интерфейса, и может управляться с помощью jQuery UI ThemeRoller

YAML (Yet Another многоколоночные Layout), направленная на гибких макетов и предлагает колонки и сетки для резиновых, эластичных или фиксированной типов дизайнов.

YAML поставляется с очень хороший Ajax строителем, удобным инструментом для визуальной разработки YAML макетов на основе CSS, который позволяет создавать макет визуально. Допустимые HTML-и CSS-код генерируется автоматически на лету. 

Смотреть демо

 YUI Grids CSS предлагает четыре предустановленных ширины страницы, шесть предустановленных шаблонов.4kb файл содержит более 1000 комбинаций макета страницы. Особенности: самоочистка нижних колонтитулов, настройка ширину фиксированного макета, поддерживает резиновые макеты и многое другое.

The YUI Grids Builder — a simple interface for Grids customization.

Смотреть демо


Мне понравились 960 CSS Framework и Blueprint CSS Framework, остальные как-то не впечатлили, а по этим двум планирую написать более детальные обзоры, возможно это будут переводы тех страниц на которые я дал ссылки в качестве мануала по ним.


UPD

Информация в статье устарела, сейчас в основном все используют Twitter Bootstrap.

Создавайте организованные веб-сайты быстро с помощью 960 Grid

В этой статье я расскажу о возможностях 960 и покажу вам, как создать макет из 12 столбцов (или другого размера, если хотите), чтобы вы могли приступить к работе с сеточными системами . Ниже у меня есть полнофункциональный пример CSS и HTML, и вы можете загрузить мой шаблон Photoshop, чтобы разработать концепции и быстро вырезать их для быстрой реализации.

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

Я использую эту систему для быстрого создания прототипов. Одним быстрым движением руки я могу создать макет, который легко использовать как в программах для графического дизайна, так и в программах для веб-дизайна. Просто укажите (или настройте) файл в Photoshop с сеткой из двенадцати направляющих по 80 пикселей. Вы можете легко разрезать дизайн и разложить его за очень короткое время, быстрее получить одобрение клиента и получить более согласованный дизайн для реализации разработки.

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

Почему 960?

Прежде всего, за последние 10 лет мне еще не приходилось садиться за рабочий стол или ноутбук с разрешением экрана ниже 960 пикселей. Хотя я знаю, что у старых мониторов максимальное разрешение составляет 800 пикселей, сетка 960 без проблем адаптируется к этому размеру. Как?

960 делится без остатка примерно дюжиной способов:

  • 2 х 480
  • 3 х 320
  • 4 х 240
  • 5 х 192
  • 6 х 160
  • 8 х 120
  • 10 х 96
  • 12 х 80
  • 15 х 64
  • 16 х 60
  • 20 х 48
  • 24 х 40
  • 30 х 32

Что это значит? Вы можете создать сетку, которая адаптируется к макету экрана любого размера.Я не использую большую часть указанных выше значений ширины столбцов (я просто не могу придумать слишком много сценариев, в которых мне нужно было бы 30 столбцов по 32 пикселя каждый). Вы можете создать довольно хорошую систему, используя всего несколько.

12 столбцов, чтобы управлять ими всеми

Я не думаю, что 12 столбцов — это идеальная сетка. На самом деле я регулярно работаю с 16 столбцами и 24 столбцами, но 12 — действительно отличное место для начала. Вот несколько сценариев макета с сеткой из 12 столбцов, построенной на сетке 960 пикселей:

(Нажмите, чтобы увидеть полную версию)

Есть и другие способы разрезать это на части, но вы должны понять, что с помощью нескольких определений CSS вы можете очень легко и эффективно разложить свою сетку.Я просто использую 12 столбцов по умолчанию, потому что они покрывают 99% того, что мне нужно. В экстремальных сценариях, когда мне нужен дизайн из 16, 20, 24 или даже 30 столбцов, его достаточно легко приспособить к дизайну, который я собираюсь вам показать.

Постановка макета

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

.
  1. Полная ширина
  2. Полуширина
  3. 1/3 ширины
  4. 2/3 ширины
  5. 1/4 ширины
  6. 3/4 ширины

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

С указанным выше макетом у вас есть вся ширина столбцов, необходимая для большинства сценариев проектирования. Полная ширина покрывает баннеры и навигацию. 3/4 и 1/4 — статьи с боковой панелью. Остальные отлично подходят для выноски и других элементов дизайна.

CSS

Теперь, когда ширина столбцов указана выше, мы можем настроить CSS. Поскольку нам нужно некоторое пространство между элементами, мы собираемся добавить ко всему поле 10 пикселей, поэтому вы увидите, как ширина меняется, чтобы отразить это.

Итак, давайте посмотрим на истоки модели CSS:

[язык исходного кода = ”css”]

body {
min-width: 960px;
маржа: авто;
}

/ * Обертка * /
.row {
width: 960px;
маржа: авто;
}

[/ исходный код]

Для начала мы просто ограничиваем ширину тела 960 пикселей. Нам нужно обернуть каждую строку нашего столбца в оболочку, которая хранит все, где оно должно быть, хотя есть несколько веских причин не иметь этого — например, макеты портфолио, в которых вы хотите, чтобы элементы перемещались друг вокруг друга.

Теперь мы устанавливаем «промежутки» — ширину между столбцами, чтобы наш текст или другие элементы дизайна не располагались друг над другом.

[язык исходного кода = ”css”]

/ * поля столбца * /
.col_12, / * полная ширина * /
.col_9, / * 3/4 ​​ширина * /
.col_8, / * 2/3 ширина * /
.col_6, / * половина ширины * /
.col_4, / * 1/3 ширины * /
.col_3 / * 1/4 ширины * /
{
margin-left: 10px;
margin-right: 10 пикселей;
дисплей: встроенный;
поплавок: левый;
}

[/ исходный код]

Я пометил каждый столбец номерами для удобства на случай, если вы забудете, какой столбец является каким.Такое случается.

Затем нам нужен способ убедиться, что крайние левые столбцы идут влево, а крайние правые столбцы — вправо.

[язык исходного кода = ”css”]

/ * Первый и последний * /
.first {
margin-left: 0;
}

.last {
margin-right: 0;
}

[/ исходный код]

Затем мы устанавливаем нашу фактическую ширину для каждого типа столбца.

[язык исходного кода = ”css”]

/ * Ширина столбца с учетом полей * /
.col_12 {width: 940px;}
.col_9 {width: 620px;}
.col_8 {width: 700px;}
.col_6 {width: 460px;}
.col_4 {width: 220px;}
.col_3 {width: 300px ;}

[/ исходный код]

Теперь давайте объединим все это в единый пакет CSS, который вы можете сохранить и сразу же использовать:

[sourcecode language = ”css”]
/ * Исправляем ширину тела * /
body {
min-width: 960px;
маржа: авто;
}

/ * Обертка * /
.row {
width: 960px;
маржа: авто;
}

/ * Поля столбца * /
.col_12, / * полная ширина * /
.col_9, / * 3/4 ​​ширина * /
.col_8, / * 2/3 ширина * /
.col_6, / * полуширина * /
.col_4, / * 1 / 3 width * /
.col_3 / * 1/4 ширины * /
{
margin-left: 10px;
margin-right: 10 пикселей;
дисплей: встроенный;
поплавок: левый;
}

/ * Первый и последний * /
.first {
margin-left: 0;
}

.last {
margin-right: 0;
}

/ * Ширина столбца с учетом полей * /
.col_12 {width: 940px;}
.col_9 {width: 620px;}
.col_8 {width: 700px;}
.col_6 {width: 460px;}
.col_4 {width: 220px;}
.col_3 {width: 300px;}

[/ исходный код]

Посмотрите на сетку 960, 12 столбцов в действии!

А теперь давайте применим это на практике. Сохраните приведенный выше код как документ CSS и назовите его «960-12-col.css». В той же папке скопируйте и вставьте следующий HTML-код:

[язык исходного кода = ”htmtl”]





Образец 960, макет сетки из 12 столбцов




Вот столбец полной ширины




Вот ширина 3/4 столбец


И это аналог ширины 1/4




Вот 2 Столбец шириной / 3


И его аналог шириной 1/3




Я сначала на 1/3 ширины


И я на 2/3 ширины в последнюю очередь




Хочешь пойти на полусвета?


Конечно, я пойду на полусвета!




Вот столбец шириной 1/3


Я тоже столбец шириной 1/3!


Я последняя 1/3 ширины: ^ (




Можем ли мы сделать 1 / 4 столбца


Конечно, мы можем сделать 1/4!


Я разделяю это мнение!

< / div>

Почему я всегда последний?: ^ (




Вот столбец нижнего колонтитула полной ширины




[/ исходный код]

Убедитесь, что таблица стилей в строке 7 совпадает с сохраненным файлом CSS.Откройте его в браузере, и вы увидите сетку в действии:

(Нажмите, чтобы увидеть полную версию)

Разметка в приведенном выше HTML добавляет несколько вещей, чтобы сделать сетку удобной для просмотра. Вы можете удалить или закомментировать раздел