Улучшаем модульную сетку
Какой бы библиотекой для модульной сетки вы не пользовались, у всех есть одна проблема - управление полем и отступом для последнего элемента <div>.
Проблема
Если вы используете модульную сетку, то каждая библиотека имеет класс, например, .grid, который определяет единичный модуль/ячейку и сопровождается кодом, похожим на следующий:
.row{
width:940px;
overflow:hidden;
clear:both;
}
.grid{
float:left;
margin-right:20px;
}
...
.col-4{
width:220px;
}
...
Очень важным моментом является факт, что каждый .grid имеет margin-right равный 20px. Поэтому в 16 колоночной сетке шириной 940px (4 × .col-4) реальная ширина будет равна 960px (4 × (220px + 20px)). То есть, на 20px (или одно поле) больше, чем занимает ваш контейнер.
Формула для расчета следующая:
f = n(c) + (n-1)(g)
Где:
- f = полная строка
- n = число ячеек в строке
- c = ширина колонки
- g = ширина интервала между колонками
То есть, строка состоит из n колонок и n-1 интервалов. Нам нужно иметь на один интервал меньше, чем количество колонок. Следовательно, от одного интервала надо как-то избавляться.
Вариант решения 1
Самый простой и распространенный способ - использовать класс .last или .end для последнего элемента сетки в строке, чтобы удалить его поле:
В данном случае разметка будет выглядеть следующим образом:
<div class="row">
<div class="grid col-4">
<p>Одна ячейка плюс один интервал</p>
</div>
<div class="grid col-4">
<p>Одна ячейка плюс один интервал</p>
</div>
<div class="grid col-4">
<p>Одна ячейка плюс один интервал</p>
</div>
<div class="grid col-4 end">
<p>Одна ячейка без интервала</p>
</div>
</div>
Рабочее решение задачи, но разработчику нужно помнить о том, что надо добавлять специальный класс к последнему элементу в строке при построении сетки.
Другая проблема с данным решением заключается в том, что если программисту надо организовать динамический вывод, например, серии изображений в стеке, нужно скрипт должен содержать функционал типа ‘если это колонка x, то добавить класс .end’. Конечно, вопрос не глобальный, но требующий дополнительного внимания и работы.
Вариант решения 2
Другой вариант решения является более элегантным, но использовать его можно не в каждом случае. Он применяется в библиотеке Twitter Bootstrap.
Убираем margin-right:20px; из класса .grid и добавляем вместо него margin-left. Затем используем псевдо селектор :first-child (:first-child лучше поддерживается в браузерах, чем :last-child). То есть, вы можете указать первый элемент div в строке и удалить поле:
.grid:first-child{
margin:0;
}
Разметка остается чистой, так как не нужно добавлять специального класса, разработчикам не нужно принимать во внимание порядок элементов. Но и в данном решении есть свои проблемы…
Самая маленькая проблема - селектор :first-child не всегда эффективно работает. Обсуждение производительности селекторов выходит за рамки нашего урока.
Более серьезная проблема заключается в том, что метод с использованием :first-child можно применять только для варианта с одной строкой в модуле сетки. /А для нескольких строк в модуле данный метод не подходит. Ниже объясняется, почему. Символы на схемах обозначают:
- Тильда (~) и разорванная вертикальная черта (¦) обозначают
.rowdiv - Тире (-) и вертикальная черта (|) обозначают
.griddiv - x обозначает
:first-child - ! обозначает неверно сформированные элементы
:first-child работает отлично в шаблонах с одной строкой в модуле. Первый элемент div является единственнымdiv без левого поля:
А на следующей схеме представлен случай, когда :first-child не действует, так как есть два элемента div, для которых нужно убирать поле слева, но первым потомком является только один. В случае наличия нескольких строк в модуле, метод не работает:
Предлагаемое решение
Идея решения заключается в том, чтобы не удалять лишнее поле, а скрывать эффект его присутствия.
Суть проблемы выражается одним предложением - строка элементов на один интервал шире, чем контейнер. Значит, нам нужно сделать наш контейнер шире на один интервал и замаскировать дополнительную ширину с помощью отрицательного значения поля равного ширине одного интервала.
Устанавливаем интервал как margin-left для .grid, но не удаляем ничего. Никаких псевдо-классов или специальных классов.
Мы скрываем эффект дополнительного интервала задавая контейнеру .row ширину, равную ширине комбинации всех колонок и интервалов, а затем устанавливаем отрицательное значение margin-leftравное ширине одного интервала, оттягивая все обратно на нужные позиции и срывая эффект margin-left для первого элемента .grid.
Наш элемент .row, который должен быть шириной 940px, будет иметь размер 960px, чтобы исключить удаление лишнего интервала. Затем мы вытянем обратно 20px, чтобы удалить визуальный эффект присутствия ненужного интервала:
.row{
width:960px;
margin-left:-20px;
overflow:hidden;
clear:both;
}
.grid{
float:left;
margin-left:20px;
}
...
.col-4{
width:220px;
}
...
Таким образом, мы можем использовать многострочную конструкцию и не нужно помнить о дополнительных классах типа .end/.last.
В действии данную технику можно увидеть на сайте inuit.css (используйте Firebug или другие отладочные инструменты для исследования разметки).
Формулировка
Для использования данной техники нужно иметь следующие исходные данные:
- Количество колонок в сетке
- Ширину одной колонки
- Ширину интервала
Формула достаточно проста:
.row{
width: количество_колонок * (ширина_одной_колонки + ширина_одного_интервала) px;
margin-left: -ширина_одного_интервала px;
overflow:hidden;
clear:both;
}
.grid{
float:left;
margin-left: ширина_одного_интервала px;
}
Например, для создания сетки с 12 колонками, которые имеют ширину 50px и интервал 25px:
.row{
width:900px;
margin-left:-25px;
overflow:hidden;
clear:both;
}
.grid{
float:left;
margin-left:25px;
}
Использование данного метода позволяет строить модульные сетки для большого количества типов шаблонов (применяя многострочные модули) без дополнительных классов (можно легко менять местами колонки).
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/S2PBcGjbXLs/lessons.php
|
Какой бы библиотекой для модульной сетки вы не пользовались, у всех есть одна проблема - управление полем и отступом для последнего элемента . ПроблемаЕсли вы используете модульную сетку, то каждая |
РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2026-03-04 » Скорость, ИИ и человекоцентричность: каким должен быть сайт в 2026 году
- 2026-03-03 » Как искусственный интеллект меняет таргетированную рекламу
- 2026-03-03 » Основные киберугрозы для бизнеса: 5 способов потерять (и сохранить) данные компании
- 2026-03-03 » Главные тренды веб-дизайна 2026 года: от гиперминимализма до кибербрутализма
- 2026-03-03 » Искусственный интеллект в маркетинге: помощник, а не замена человеку
- 2026-02-26 » Нулевая позиция в поиске: как на нее попасть и зачем это нужно
- 2026-02-26 » Как выбрать подрядчика для сайта и не попасть на мошенников
- 2026-02-26 » Инклюзивный клиентский опыт: как сделать бизнес доступным для всех и повысить конверсию
- 2026-02-26 » ESG-принципы: что это такое и как бизнесу внедрять их в свою работу
- 2026-02-26 » Почему в 2026 году маркетологу не стоит бояться искусственного интеллекта
- 2026-02-22 » No-code vs Профессиональная разработка: выстрелит ли Tilda в 2026 году?
- 2026-02-22 » Почему малый бизнес проигрывает в контекстной рекламе и при чем тут структура сайта
- 2026-02-22 » Куда уходит скорость: как мы теряем посетителей из-за одного "тяжелого" шрифта
- 2026-02-22 » Дарк-паттерны (Dark Patterns) в интерфейсах: когда манипуляция клиентом выходит боком
- 2026-02-22 » Голосовой поиск и веб: готов ли ваш сайт к разговору с Алисой и Марусей?
- 2026-02-22 » Микроанимация и UX/UI: как движение элементов влияет на конверсию
- 2026-02-22 » ИИ в веб-аналитике: как нейросети предсказывают отток клиентов до того, как они уйдут
- 2026-02-22 » Темная сторона шаблонов: почему сайт на готовом решении может угробить ваш бизнес
- 2026-02-22 » Зеленый хостинг и экология в IT: тренд или необходимость?
- 2026-02-22 » Веб-доступность (Accessibility): почему ваш сайт теряет до 20% клиентов и штрафует сам себя
- 2026-02-12 » Экономика фриланса vs веб-студии: скрытые издержки и риски при заказе сайта «у знакомого разработчика»
- 2026-02-12 » Инструменты аналитики помимо Google Analytics
- 2026-02-12 » Юридические аспекты владения сайтом
- 2026-02-12 » Сравниваем популярные CRM-системы для интеграции с сайтом
- 2026-02-12 » Эволюция интерфейсов: от CLI к GUI, к VUI и далее
- 2026-02-12 » Контент-стратегия после обновления Google Helpful Content
- 2026-02-12 » Headless-архитектура: модный тренд или необходимость для вашего бизнеса?
- 2026-02-12 » Мифы о кибербезопасности для малого и среднего бизнеса
- 2026-02-12 » Как Core Web Vitals влияют не только на SEO, но и на конверсию?
- 2026-02-12 » PWA vs Нативное приложение: что выбрать малому бизнесу в 2026?
Не делай другим то, что ты хотел бы, чтобы они делали для тебя. У вас могут быть разные вкусы Шоу Джордж Бернард - (1856-1950) - английский писатель. В своем творчестве ниспровергал догматизм и предвзятость, традиционность представлений |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.

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