Вы когда-нибудь использовали обычные плагины для аккордеона в своих проектах? Я бы поверил в это! Большинство из них используют JavaScript для работы (или jQuery). Обычно мы используем такие плагины (аккордеоны) для создания промо с изображениями, небольшой фотогалереей или в случае, если нам нужно создать рекламу со списком характеристик продукта. Мы провели некоторое исследование и пришли к выводу, что иногда нам не нужно использовать какой-либо сценарий для создания аккордеонов. Мы можем просто использовать силу CSS3. Мы можем обработать событие OnClick и использовать собственную анимацию.
Я подготовил три версии с аккордеоном. Для первой демонстрации мы используем jQuery для создания аккордеона. Я выбрал плагин liteAccordion jQuery (http://nicolahibbert.com/demo/liteAccordion/) в качестве плагина аккордеона для наших тестовых целей. Увидеть как это работает:
Это выглядит красиво, не так ли? Давайте рассмотрим HTML-разметку этой страницы:
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>How to turn jQuery accordion into pure CSS3 accordion | Script Tutorials</title>
<!-- CSS files -->
<link href="css/layout.css" rel="stylesheet" />
<link href="css/liteaccordion.css" rel="stylesheet" />
<!-- jQuery -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<!-- jQuery easing -->
<script src="js/jquery.easing.1.3.js"></script>
<!-- liteAccordion jQuery library -->
<script src="js/liteaccordion.jquery.js"></script>
<script>
$(document).ready(function(){
$('#js_version').liteAccordion({
theme : 'dark',
rounded : true,
enumerateSlides : true,
firstSlide : 1,
linkable : true,
easing: 'easeInOutSine'
});
});
</script>
</head>
<body>
<h1>jQuery accordion (liteAccordion) version</h1>
<div id="js_version" class="accordion">
<ol>
<li data-slide-name="slide1">
<h2><span>Slide One</span></h2>
<div>
<img src="images/1.jpg" alt="Slide One" />
</div>
</li>
<li data-slide-name="slide2">
<h2><span>Slide Two</span></h2>
<div>
<img src="images/2.jpg" alt="Slide Two" />
</div>
</li>
<li data-slide-name="slide3">
<h2><span>Slide Three</span></h2>
<div>
<img src="images/3.jpg" alt="Slide Three" />
</div>
</li>
<li data-slide-name="slide4">
<h2><span>Slide Four</span></h2>
<div>
<img src="images/4.jpg" width="768" alt="Slide Four" />
</div>
</li>
<li data-slide-name="slide5">
<h2><span>Slide Five</span></h2>
<div>
<img src="images/5.jpg" alt="Slide Five" />
</div>
</li>
</ol>
<noscript>
<p>Please enable JavaScript to get the full experience.</p>
</noscript>
</div>
</body>
</html>
В заголовок мы добавили все необходимые библиотеки и стили (библиотека jQuery, jquery.easing и liteAccordion), а также код инициализации аккордеона. В разделе тела мы видим основную структуру аккордеона (список OL-LI) со слайдами. Я думаю, что это одна из обычных структур для аккордеонов.
Теперь я думаю, что самое время начать превращать его в чистый аккордеон CSS3. В начале мы должны удалить все скрипты JS со своей страницы, мы также можем удалить liteaccordion.css. Мы собираемся подготовить наши собственные стили CSS. Кроме того, мы должны добавить ссылки <A> к заголовкам наших слайдов (потому что мы должны иметь возможность переключаться между слайдами). В результате мы должны получить что-то вроде этого:
<!DOCTYPE HTML> <html lang="en"> <head> <meta charset="utf-8" /> <!-- CSS files --> <link href="css/layout.css" rel="stylesheet" /> <link href="css/main.css" rel="stylesheet" /> </head> <body> <h1>Pure CSS3 accordion version without animation</h1> <div class="accordion css3accordion"> <span id="slide1"></span> <span id="slide2"></span> <span id="slide3"></span> <span id="slide4"></span> <span id="slide5"></span> <ol> <li class="slide1"> <a href="#slide1"><h2><span>Slide One</span></h2></a> <div> <img src="images/1.jpg" alt="Slide One" /> </div> </li> <li class="slide2"> <a href="#slide2"><h2><span>Slide Two</span></h2></a> <div> <img src="images/2.jpg" alt="Slide Two" /> </div> </li> <li class="slide3"> <a href="#slide3"><h2><span>Slide Three</span></h2></a> <div> <img src="images/3.jpg" alt="Slide Three" /> </div> </li> <li class="slide4"> <a href="#slide4"><h2><span>Slide Four</span></h2></a> <div> <img src="images/4.jpg" alt="Slide Four" /> </div> </li> <li class="slide5"> <a href="#slide5"><h2><span>Slide Five</span></h2></a> <div> <img src="images/5.jpg" alt="Slide Five" /> </div> </li> </ol> </div> </body> </html>
Как видите, я добавил несколько объектов <span>. По умолчанию все они скрыты, но мы должны использовать их для обработки событий onclick. Теперь мы готовы начать писать собственные стили для нашего аккордеона CSS3. Во-первых, мы должны определить стили для нашего родительского объекта и внутренних областей:
/* CSS3 accordion */
.css3accordion {
border: 9px solid #353535;
border-radius: 6px;
padding: 5px 5px 6px 0;
background: #030303;
height: 320px;
width: 960px;
/* CSS3 shadows */
-webkit-box-shadow: 0 -1px 0 #555 inset, 0 5px 15px rgba(0, 0, 0, 0.5);
-moz-box-shadow: 0 -1px 0 #555 inset, 0 5px 15px rgba(0, 0, 0, 0.5);
-ms-box-shadow: 0 -1px 0 #555 inset, 0 5px 15px rgba(0, 0, 0, 0.5);
-o-box-shadow: 0 -1px 0 #555 inset, 0 5px 15px rgba(0, 0, 0, 0.5);
box-shadow: 0 -1px 0 #555 inset, 0 5px 15px rgba(0, 0, 0, 0.5);
}
/* hide first level spans */
.css3accordion > span {
display: none
}
Как я уже сказал — они скрыты. Теперь мы можем определить стили для наших слайдов и заголовков:
/* main accordion styles and slides */
.css3accordion ol {
height: 100%;
list-style: none;
overflow: hidden;
position: relative;
}
.css3accordion li {
float: left;
height: 100%;
overflow: hidden;
position: relative;
width: 48px;
/* CSS3 transition for slides */
-webkit-transition: all 0.9s ease-in-out;
-moz-transition: all 0.9s ease-in-out;
-ms-transition: all 0.9s ease-in-out;
-o-transition: all 0.9s ease-in-out;
transition: all 0.9s ease-in-out;
}
.css3accordion li a {
display: block;
float: left;
height: 320px;
position: relative;
width: 48px;
}
/* slide headers */
.css3accordion h2 {
font-size: 16px;
font-weight: normal;
height: 48px;
left: 0;
line-height: 265%;
margin: 0;
position: absolute;
top: 0;
width: 320px;
z-index: 1;
-webkit-backface-visibility: hidden;
-webkit-transform: translateX(-100%) rotate(-90deg);
-webkit-transform-origin: right top;
-moz-transform: translateX(-100%) rotate(-90deg);
-moz-transform-origin: right top;
-ms-transform: translateX(-100%) rotate(-90deg);
-ms-transform-origin: right top;
-o-transform: translateX(-100%) rotate(-90deg);
-o-transform-origin: right top;
transform: translateX(-100%) rotate(-90deg);
transform-origin: right top;
}
.css3accordion h2 span {
background-color: #353535;
border-radius: 4px;
color: #fff;
display: block;
margin-top: 5px;
padding-right: 10%;
text-align: right;
-webkit-user-select: none;
-moz-user-select: none;
-ms-user-select: none;
-o-user-select: none;
user-select: none;
}
.css3accordion h2 span:hover {
background-color: #353535;
background: -webkit-gradient(linear, left top, right top, color-stop(0%,#353535), color-stop(100%,#555555));
background: -webkit-linear-gradient(left, #353535 0%,#555555 100%);
background: -moz-linear-gradient(left, #353535 0%, #555555 100%);
background: -ms-linear-gradient(left, #353535 0%,#555555 100%);
background: -o-linear-gradient(left, #353535 0%,#555555 100%);
background: linear-gradient(left, #353535 0%,#555555 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#353535', endColorstr='#555555',GradientType=1 );
}
/* inner slide content */
.css3accordion li div {
margin-left: 5px;
padding-left: 48px;
}
Теперь я хотел бы показать вам, как отображать счетчик в каждом заголовке. Я собираюсь использовать: после псевдоэлемента. Я надеюсь, что вы знаете, что: после селектора вставляет содержимое после выбранного элемента, поэтому мы можем сделать что-то вроде этого:
/* 'counter' object */
.css3accordion h2 span:after {
color: #080808;
font-weight: bold;
left: 10%;
position: absolute;
text-shadow: -1px 1px 0 #555555;
top: 10%;
/* CSS3 rotate for 'counter' */
-webkit-transform: rotate(90deg);
-moz-transform: rotate(90deg);
-ms-transform: rotate(90deg);
-o-transform: rotate(90deg);
transform: rotate(90deg);
}
/* 'counter' values */
li.slide1 h2 span:after {
content: "1";
}
li.slide2 h2 span:after {
content: "2";
}
li.slide3 h2 span:after {
content: "3";
}
li.slide4 h2 span:after {
content: "4";
}
li.slide5 h2 span:after {
content: "5";
}
Наконец, чтобы завершить наш аккордеон, мы должны реализовать поведение onclick:
/* onclick behavior */
#slide1:target ~ ol li.slide1,
#slide2:target ~ ol li.slide2,
#slide3:target ~ ol li.slide3,
#slide4:target ~ ol li.slide4,
#slide5:target ~ ol li.slide5 {
width: 768px;
}
#slide1:target ~ ol li.slide1 span,
#slide2:target ~ ol li.slide2 span,
#slide3:target ~ ol li.slide3 span,
#slide4:target ~ ol li.slide4 span,
#slide5:target ~ ol li.slide5 span {
background: #353535;
background: -webkit-gradient(linear, left top, right top, color-stop(0%,#353535), color-stop(100%,#555555));
background: -webkit-linear-gradient(left, #353535 0%,#555555 100%);
background: -moz-linear-gradient(left, #353535 0%, #555555 100%);
background: -ms-linear-gradient(left, #353535 0%,#555555 100%);
background: -o-linear-gradient(left, #353535 0%,#555555 100%);
background: linear-gradient(left, #353535 0%,#555555 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#353535', endColorstr='#555555',GradientType=1 );
}
Вот и все, наш собственный CSS3-аккордеон готов! Вы можете проверить это в действии:
CSS3 аккордеонная демонстрация
Но это еще не все на сегодня, в качестве бонуса я подготовил для вас третью демоверсию с анимированным аккордеоном.
анимированная демонстрация аккордеона
Для этого я рекомендую отключить поведение onclick и применить новую анимацию:
/* auto animation */
.css3accordion li {
-webkit-animation-name: anim_slides;
-webkit-animation-duration: 25.0s;
-webkit-animation-timing-function: ease-in-out;
-webkit-animation-iteration-count: infinite;
-webkit-animation-direction: normal;
-webkit-animation-delay: 0;
-webkit-animation-play-state: running;
-webkit-animation-fill-mode: forwards;
-moz-animation-name: anim_slides;
-moz-animation-duration: 25.0s;
-moz-animation-timing-function: ease-in-out;
-moz-animation-iteration-count: infinite;
-moz-animation-direction: normal;
-moz-animation-delay: 0;
-moz-animation-play-state: running;
-moz-animation-fill-mode: forwards;
}
.css3accordion li:nth-child(2) {
-webkit-animation-delay: 5.0s;
-moz-animation-delay: 5.0s;
}
.css3accordion li:nth-child(3) {
-webkit-animation-delay: 10.0s;
-moz-animation-delay: 10.0s;
}
.css3accordion li:nth-child(4) {
-webkit-animation-delay: 15.0s;
-moz-animation-delay: 15.0s;
}
.css3accordion li:nth-child(5) {
-webkit-animation-delay: 20.0s;
-moz-animation-delay: 20.0s;
}
@-webkit-keyframes anim_slides {
0% {
width: 48px;
}
20% {
width: 768px;
}
40% {
width: 48px;
}
100% {
width: 48px;
}
}
@-moz-keyframes anim_slides {
0% {
width: 48px;
}
20% {
width: 768px;
}
40% {
width: 48px;
}
100% {
width: 48px;
}
}
Вывод
Теперь это все на сегодня. Мы только что создали три разных демо: первое с jQuery, второе и третье с чистым CSS3. Я надеюсь, что вам это нравится. Удачи!