Download - Роман Комаров "Сложная вёрстка в примерах"
![Page 1: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/1.jpg)
Я.Субботник, Москва, 3 июля 2010 года
Разработчик интерфейсовРоман Комаров
Сложная вёрстка в примерах
1
![Page 2: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/2.jpg)
Просто скопом всякое про вёрстку:
— Пара замечаний о независимых блоках.
— Несколько банальных, но полезных вещей, о которых не все вспоминают.
— inline-block и все все все.
— Вёрстка в условиях масштабирования.
— Активная область элемента.
2
![Page 3: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/3.jpg)
Всё это так или иначе используется в вёрстке новой Яндекс.Почты
3
![Page 4: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/4.jpg)
Пара замечаний о независимых блоках
Желательно избегать или же несколько раз подумать перед использованием следующих свойств при вёрстке врапперов абсолютно независимых блоков:
— overflow: hidden;
— float: left|right;
— position: relative.
4
![Page 5: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/5.jpg)
overflow: hidden;
Делает практически невозможным вынос каких-либо элементов за пределы соответствующего блока.
5
![Page 6: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/6.jpg)
float
— Разрывают поток — неизвестно в каком контексте будет применяться блок.
— Существует достаточно проблем в разных браузерах.
— Если нужен блок шириной по контенту, лучше использовать inline-block.
6
![Page 7: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/7.jpg)
position: relative
— Создаётся контекст позиционирования — не всегда нужно.
— Проблемы с z-index в IE.
Хотя это очень полезное свойство и лечит большое количество багов. Но если получится что-то сверстать без его использования — при прочих равных это будет лучше.
7
![Page 8: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/8.jpg)
Несколько банальных, но полезных вещей, о которых не все вспоминают
— Абсолютные блоки в контексте потока.
— Недостатки hasLayout.
— Возможности overflow:hidden.
— Разрыв ссылки («ссылка в ссылке»).
— CSS3 селекторы и псевдоэлементы для прогрессивного улучшения.
8
![Page 9: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/9.jpg)
Абсолютные блоки в контексте потока
9
![Page 10: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/10.jpg)
Блоки с hasLayout портят схлопывающиеся блоки с неизвестной шириной
В ие IE6:
В ие IE7:
10
![Page 11: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/11.jpg)
Возможности overflow:hidden— Можно делать раскладки с одной колонкой
неизвестной ширины (с ограничениями).
— Уже можно применять overflow-y и overflow-x.
— Если у блока с overflow нет позиционирования, то внутренние блоки с абсолютным позиционированием можно вытащить наружу.
11
![Page 12: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/12.jpg)
Разрыв ссылки («ссылка в ссылке»)
12
![Page 13: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/13.jpg)
CSS3 селекторы и псевдоэлементы для прогрессивного улучшения.
Примерно так оно выглядит в Fx 3.0, если не отключить:
13
![Page 14: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/14.jpg)
inline-block и все все всеКонтейнер мёда:
— Собственный контекст — «hasLayout» для всех.
— Гибкость — то, что нельзя сделать иначе.
— Универсальность.
Ведро дёгтя:
— Много хаков для поддержки в старых браузерах.
— Большое количество лишних врапперов.
— Практически во всех браузерах можно найти те или иные баги.
14
![Page 15: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/15.jpg)
Меню на inline-block, выравненное по центру и распределённое по ширине
15
![Page 16: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/16.jpg)
Вёрстка в условиях масштабирования
— Относительные единицы и их округление
— Просвечивающие спрайты и картинки
— Визуальное соединение блоков
16
![Page 17: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/17.jpg)
Просвечивающие спрайты и картинки
— В опере при положительном зуме картинка в фоне даже при no-repeat добавляет справа левые пиксели.
— В опере (и IE7+) при зуме у спрайтов появляются паразитные пиксели со всех сторон.
— Тогда как в сафари появляются только сверху и справа.
17
![Page 18: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/18.jpg)
Визуальное соединение блоков
Исправить можно:
— Изменить вёрстку так, чтобы были другие погрешности.
— Расположением блоков «внахлёст».
— Позиционируя с запасом.
18
![Page 19: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/19.jpg)
Активная область элемента
— Пиксель-хантинг на примере постраничной навигации.
— Инпуты и лейблы.
— Просветы в ссылках при большом межстрочном расстоянии.
— Большие блоки с неоднородным контентом — варианты решения.
19
![Page 20: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/20.jpg)
Пиксель-хантинг на примере постраничной навигации.
20
![Page 21: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/21.jpg)
Инпуты и лейблы
21
![Page 22: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/22.jpg)
Просветы в ссылках при большом межстрочном расстоянии
22
![Page 23: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/23.jpg)
Большие блоки с неоднородным контентом — варианты решения.
— HTML5: блочные элементы внутри ссылки.
— Позиционирование прозрачного блока из ссылки наружу.
23
![Page 24: Роман Комаров "Сложная вёрстка в примерах"](https://reader033.vdocuments.pub/reader033/viewer/2022052412/557fc018d8b42a40118b4ed1/html5/thumbnails/24.jpg)
Разработчик интерфейсов
119021, Россия, Москва, ул. Льва Толстого, д.16
Роман Комаров
24