jQuery Слайдер с 3D эффектом перелистывания слайдов

Html
И так, что нам нужно, что бы построить наш слайдер? Небольшая разметка, включающая в себя наши картинки, стрелки переключения и навигацию в виде точек.
Так будет выглядеть наша разметка:

Код
<div class="slider">
<img src="images/1.jpg" alt="">
<img src="images/2.jpg" alt="">
<img src="images/3.jpg" alt="">
<div class="buttons">  
<a href="#" class="prev"></a>
<a href="#" class="next"></a>
</div>  
<span class="nav"></span>
</div>

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

Код

.slider {
  position:relative;
  width: 960px;
  height: 450px;
  margin: 0 auto;
}
.slider img {
  position: absolute;
  top:0px;
  left:0px;
  display: none;
  background-color: #f3f4ef;
  border: 13px solid #dedede;
}
.slider .active {
  display: block;
  z-index: 100;
}
.nav {
  z-index: 1000;
  position: absolute;
  bottom: 0;
  text-align: center;
  width: 100%;
  padding: 10px 0 20px 0;
}
.nav a {
  margin-right: 15px;
  display: inline-block;
  border-radius: 50%;
  width: 10px;
  background: #fff;
  height: 10px;
}
.nav .navActive {
  background: #666;
  border: none;
}
.buttons {
  width: 100%;
  position:absolute;
}
.buttons a {
  position:absolute;
  z-index: 1000;
  top: 230px;
  height: 30px;
  width: 30px;
  background: url(../images/arrow.jpg);
}
.buttons .prev {
  left:20px;
}
.buttons .next {
  right:20px;
  background-position: 30px 30px;
}
body {
  -webkit-backface-visibility: hidden;
}

JS
Теперь напишем наш обработчик, который будет переключать наши слайды при нажатии на кнопки управления и функцию для автоматизации процесса!
Не забудьте подключить jQuery!!!

Код
$(function () {
  var duration = 2500;
  var slides = $(".slider img").length;
  var i = 1;
  $(".slider img:nth-child(1)").addClass("active animated flipInX");
  function slide() {
  if (i <= slides) {
  var imagelocation = ".slider img:nth-child(" + i + ")";
  var navlocation = ".nav a:nth-child(" + i + ")";
  $(imagelocation).siblings().removeClass("active animated flipInX");
  $(imagelocation).addClass("active animated flipInX");
  $(navlocation).siblings().removeClass("navActive");
  $(navlocation).addClass("navActive");
  }
  if (i == 0) {
  i = slides;
  }
  if (i < 0) {
  i = 0;
  }
  }
  // Добавляем круглые кнопочки
  var blips = 0;
  for (var nav = 0; nav < slides; nav++) {
  $(".nav").append('<a href="#"></a>');
  }
  $(".nav a:first-child").addClass("navActive");
  // Функция для переключения слайдов при нажатии на стрелки
  $('.next').click(function () {
  clearInterval(timer);
  if (i == slides) {
  i = 1;
  } else {
  i++
  }
  slide();
  console.log(i);
  })
  $('.prev').click(function () {
  clearInterval(timer);
  if (i == 1) {
  i = slides;
  } else {
  i--
  }
  slide();
  console.log(i);
  })
  // Автопроигрывание
  timer = setInterval(function () {
  i++;
  if (i > slides) {
  i = 1;
  }
  slide();
  }, duration);
});

Все, теперь наш слайдер работает! Но мы так и не сделали эффекты 3D пролистывания. Нам нужно создать класс в таблице CSS, который будет анимировать активный слайд.
Пишем следующий код:

Код
.animated {
  -webkit-animation-duration: 1s;
  -moz-animation-duration: 1s;
  -o-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  -moz-animation-fill-mode: both;
  -o-animation-fill-mode: both;
  animation-fill-mode: both;
}
@-webkit-keyframes flipInX {
  0% {
  -webkit-transform: perspective(400px) rotateX(90deg);
  opacity: 0;
  }
  40% {
  -webkit-transform: perspective(400px) rotateX(-10deg);
  }
  70% {
  -webkit-transform: perspective(400px) rotateX(10deg);
  }
  100% {
  -webkit-transform: perspective(400px) rotateX(0deg);
  opacity: 1;
  }
}
@-moz-keyframes flipInX {
  0% {
  -moz-transform: perspective(400px) rotateX(90deg);
  opacity: 0;
  }
  40% {
  -moz-transform: perspective(400px) rotateX(-10deg);
  }
  70% {
  -moz-transform: perspective(400px) rotateX(10deg);
  }
  100% {
  -moz-transform: perspective(400px) rotateX(0deg);
  opacity: 1;
  }
}
@-o-keyframes flipInX {
  0% {
  -o-transform: perspective(400px) rotateX(90deg);
  opacity: 0;
  }
  40% {
  -o-transform: perspective(400px) rotateX(-10deg);
  }
  70% {
  -o-transform: perspective(400px) rotateX(10deg);
  }
  100% {
  -o-transform: perspective(400px) rotateX(0deg);
  opacity: 1;
  }
}
@keyframes flipInX {
  0% {
  transform: perspective(400px) rotateX(90deg);
  opacity: 0;
  }
  40% {
  transform: perspective(400px) rotateX(-10deg);
  }
  70% {
  transform: perspective(400px) rotateX(10deg);
  }
  100% {
  transform: perspective(400px) rotateX(0deg);
  opacity: 1;
  }
}
.animated.flipInX {
  -webkit-backface-visibility: visible !important;
  -webkit-animation-name: flipInX;
  -moz-backface-visibility: visible !important;
  -moz-animation-name: flipInX;
  -o-backface-visibility: visible !important;
  -o-animation-name: flipInX;
  backface-visibility: visible !important;
}

Вот теперь мы можем насладиться нашим слайдером. Спс за внимание!

  • FalleN

  • 4472

  • 1

  • 294

Ссылки на статью:

Похожие статьи: