- Автор: --------------
- Адаптировал: irbees2008
- Уровень сложности исполнения: нужны навыки css hmlt
Известны 3 способа организации вкладок на чистом CSS — при помощи overflow, :checked и :target. Пристального рассмотрения заслуживают первые два из них.
Итак, как же сделать переключение табов на CSS? Как мы помним, CSS и HTML являются чисто описательными языками. якорь заставляет браузер найти место в документе, содержащее якорь, и прокрутить страницу до него.
Также мы вспоминаем, что CSS позволяет описывать контейнеры, которые по ширине и/или высоте меньше, чем содержимое в контейнере. А что происходит с содержимым, выходящим за границы контейнера? Если у контейнера установлен аттрибут overflow: hidden то такое содержимое не отображается. Получается маленькое «окно», через которое нам видна часть большего региона.
Эти два факта позволяют организовать вкладочный интерфейс. В заголовках вкладок мы расположим ссылки на якори. А сами якори расположим на содержимом вкладок. При этом блок, внутри которого находится содержимое вкладок («окно»), ограничим в размерах так, чтобы одновременно через него была видна только одна вкладка. Работать это будет следующим образом: когда мы нажимаем на ссылку в заголовке вкладки, браузеру нужно показать нам соответтсвующий ярлык. И он будет прокручивать вкладки так, чтобы запрашиваемый якорь оказался в «окне».
HTML код для вкладок будет выглядеть следующим образом:
<div class="notebook" id="notebook1">
<ul class="tabs">
<li><a href="#tab1-1">Первая</a></li>
<li><a href="#tab1-2">Вторая</a></li>
<li><a href="#tab1-3">И третья</a></li>
<li><a href="#tab1-4">Даже четвертая</a></li>
<li><a href="#tab1-5">И совсем уж пятая</a></li>
</ul>
<ul class="pages">
<li id="tab1-1">1</li>
<li id="tab1-2">2</li>
<li id="tab1-3">3</li>
<li id="tab1-4">4</li>
<li id="tab1-5">5</li>
</ul>
</div>
CSS довольно прост. Сначала задаем базовые параметры внешнего вида:
.notebook > *, .notebook > * > * {
margin: 0;
padding: 0;
}
.notebook > .tabs, .notebook > .pages {
list-style: none;
overflow: hidden;
}
.notebook > .tabs a {
float: left;
}
Горизонтальный список вкладок (вместо вертикального) формируется при помощи float: left.
Кстати, во фреймворках для отображения графического интерфейса виджет, формирующий вкладки, обычно называется notebook. Поэтому CSS-класс для нашей панели вкладок я тоже назвал notebook.
Затем придадим нашим вкладкам привычный вид:
.notebook > .tabs > li > * {
border-left: 1px gray solid;
border-top: 1px gray solid;
}
.notebook > .tabs > li:last-child > * {
border-right: 1px gray solid;
}
.notebook > .pages {
border: 1px gray solid;
}
.notebook > .tabs {
font-family: Georgia;
font-size: 12px;
line-height: 30px;
height: 30px;
}
.notebook > .tabs a {
background: #eee;
padding: 0 10px;
text-decoration: none;
height: 30px;
}
.notebook > .tabs a:hover {
background: #ddd;
}
Также мы тут задаём внешний вид текста этих ссылок — шрифт, размер и т.п.
Ну и наконец задаем фиксированные размеры для вкладок и для контейнера вкладок, что в итоге и даст нам возможность прокрутки:
#notebook1 > .pages, #notebook1 > .pages > li {
width: 500px;
height: 200px;
}
Данный способ организации вкладок удобен тем, что вы можете не только переключать вкладки в пределах страницы, но и легко сослаться на нужную вкладку с другой страницы. Можно поставить ссылку из другого документа, содержащую якорь нужной вкладки, и при переходе по такой ссылке страница откроется на заданной вкладке.
С другой стороны, как я уже выше отметил, если содержимое страницы не умещается на один экран, страница будет дергаться при переключении вкладок. Если вы делаете что-то типа веб-приложения, в котором возможность прокрутки страницы вообще не предполагается, то такой способ вам вполне подойдёт. Если у вас вкладки расположены в нижней части страницы (например, в футере под содержимым статей блога), то тоже всё нормально — дергания не будет, т.к. дальше прокручивать страницу некуда.
Также к недостаткам переключения вкладок overflow-способом можно отнести невозможность «правильным образом» сделать выделение заголовка текущей вкладки. Как вы заметили, в примерах выше все табы выглядят одинаково, независимо от того, какая вкладка открыта. Под правильным способом я подразумеваю способ, которые делается через CSS, без необходимости добавлять дополнительные элементы в html-код.
Тем не менее, существует хоть и «неправильный», но вполне рабочий способ добиться визуальной индикации текущей вкладки. У этого способа есть только одно ограничение: точная ширина заголовков вкладок должна быть нам известна заранее.
Посмотрим — что у нас изменяется при переключении вкладок? Изменяется только видимая область в прокручиваемом «окне». Значит, у нас единственный выход: элементы оформления, показывающие активную вкладку, должны быть привязаны к содержимому вкладки.
Возьмём панель с 4-мя вкладками. В начало содержимого каждой вкладки добавим div, содержащий 4 тега p. (Тегов должно быть по числу вкладок. Если у вас будет 5 вкладок, ставьте по 5 тегов p.)
<div class="notebook" id="notebook4">
<ul class="tabs">
<li><a href="#tab4-1">Первая</a></li>
<li><a href="#tab4-2">Вторая</a></li>
<li><a href="#tab4-3">Третья</a></li>
<li><a href="#tab4-4">Четвертая</a></li>
</ul>
<ul class="pages">
<li id="tab4-1">
<div class="page-top-border"><p></p><p></p><p></p><p></p></div>
1
</li>
<li id="tab4-2">
<div class="page-top-border"><p></p><p></p><p></p><p></p></div>
2
</li>
<li id="tab4-3">
<div class="page-top-border"><p></p><p></p><p></p><p></p></div>
3
</li>
<li id="tab4-4">
<div class="page-top-border"><p></p><p></p><p></p><p></p></div>
4
</li>
</ul>
</div>
Пишем CSS. Сначала часть, привязанная к классу notebook (т.е. общая для любых панелей вкладок):
.notebook > .pages > li > .page-top-border
{
margin: 0px;
padding: 0px;
border: none;
}
.notebook > .pages > li > .page-top-border > p
{
height: 1px;
background: gray;
float: left;
margin: 0px;
padding: 0px;
border: none;
}
Это еще не всё, что относится к классу notebook. Вот самая интересная часть магии:
.notebook > .pages > :nth-child(1) > .page-top-border> :nth-child(1),
.notebook > .pages > :nth-child(2) > .page-top-border> :nth-child(2),
.notebook > .pages > :nth-child(3) > .page-top-border> :nth-child(3),
.notebook > .pages > :nth-child(4) > .page-top-border> :nth-child(4)
{
background: inherit !important;
}
Селектор
.notebook > .pages > :nth-child(1)
.page-top-border> :nth-child(1)
Теперь допишем стили, специфичные для конкретной панели:
#notebook4 > .pages {
border-top: none;
}
#notebook4 > .pages, #notebook4 > .pages > li {
width: 400px;
height: 150px;
box-sizing: border-box;
}
#notebook4 > .tabs > li > a,
#notebook4 > .pages > li > .page-top-border > p {
width: 100px;
box-sizing: border-box;
}
Затем мы задаём размеры панели вкладок, ширину заголовков вкладок и сегментов границы. Важно, чтобы ширина вкладок и сегментов совпадала.
Свойство box-sizing: border-box указывает, что реальные размеры нужно считать с учетом ширины отступов и границ. (Без этого свойства браузер добавляет размеры отступов и границ к заданной в CSS ширине и высоте блоков.)
Исходный код CSS целиком:
.notebook > *, .notebook > * > * {
margin: 0;
padding: 0;
}
.notebook > .tabs, .notebook > .pages {
list-style: none;
overflow: hidden;
}
.notebook > .tabs a {
float: left;
}
.notebook > .tabs > li > * {
border-left: 1px gray solid;
border-top: 1px gray solid;
}
.notebook > .tabs > li:last-child > * {
border-right: 1px gray solid;
}
.notebook > .pages {
border: 1px gray solid;
}
.notebook > .tabs {
font-family: Georgia;
font-size: 12px;
line-height: 30px;
height: 30px;
}
.notebook > .tabs a {
background: #eee;
padding: 0 10px;
text-decoration: none;
height: 30px;
}
.notebook > .tabs a:hover {
background: #ddd;
}
#notebook1 > .pages, #notebook1 > .pages > li {
width: 500px;
height: 200px;
}
#notebook1 > .pages {
text-align: center;
line-height: 200px;
font-size: 150px;
}
#tab1-1 { background: #d81; }
#tab1-2 { background: #8d1; }
#tab1-3 { background: #1d8; }
#tab1-4 { background: #18d; }
#tab1-5 { background: #81d; }
#notebook2 > .pages, #notebook2 > .pages > li {
width: 320px;
height: 320px;
}
#notebook3 > .pages, #notebook3 > .pages > li {
width: 300px;
height: 250px;
}
#notebook3, #tab2-1 > img, #tab2-2 > img {
padding: 5px;
}
.notebook > .pages > li > .page-top-border
{
margin: 0px;
padding: 0px;
border: none;
}
.notebook > .pages > li > .page-top-border > p
{
height: 1px;
background: gray;
float: left;
margin: 0px;
padding: 0px;
border: none;
}
.notebook > .pages > :nth-child(1) > .page-top-border> :nth-child(1),
.notebook > .pages > :nth-child(2) > .page-top-border> :nth-child(2),
.notebook > .pages > :nth-child(3) > .page-top-border> :nth-child(3),
.notebook > .pages > :nth-child(4) > .page-top-border> :nth-child(4)
{
background: inherit !important;
}
#notebook4 > .pages {
border-top: none;
}
#notebook4 > .pages, #notebook4 > .pages > li {
width: 400px;
height: 150px;
box-sizing: border-box;
}
#notebook4 > .tabs > li > a,
#notebook4 > .pages > li > .page-top-border > p {
width: 100px;
box-sizing: border-box;
}
Можешь почитать и вот эту статейку "Хочу кнопку submit вне формы"
Это тоже интересно
- 09.06.13Вкладки-Табы на jQuery и CSS
- 16.04.13Выпадающее меню на CSS
Мы рекомендуем Вам зарегистрироваться либо войти на сайт под своим именем.