Анимированное меню с 3D эффектом на CSS

В данном уроке мы сделаем простое меню с 3D эффектом при наведении курсора мыши на пункт меню.

HTML

Структура HTML состоит из списка со ссылками, то есть типовой конструктив для меню навигации. Однако каждый пункт содержит несколько дополнительных элементов SPAN для реализации 3D эффекта:

<ul class="block-menu">
  <li><a href="/" class="three-d">
    Главная
    <span aria-hidden="true" class="three-d-box">
      <span class="front">Главная</span>
      <span class="back">Кто мы</span>
    </span>
  </a></li>
  <li><a href="/demos" class="three-d">
    Демо
    <span aria-hidden="true" class="three-d-box">
      <span class="front">Демо</span>
      <span class="back">Ух ты!</span>
    </span>
  </a></li>
  <!-- другие пункты меню -->
</ul>

Кроме основного элемента  A имеется серия элементов SPAN, которые используются для представления "лицевой" и "задней" частей для 3D анимации.  Нужно подбирать ширину текста для всех элементов, чтобы она была одинаковой.

 

CSS

Анимация основана на трансформациях и переходах. Элемент A не перемещается, все выполняет родительский элемент SPAN. Каждый внутренний элемент SPAN получает свое положение и не изменяет его. Каждый из них анимируется с движением вверх или вниз с помощью трансформаций и переходов CSS.

/* Основные стили меню */
.block-menu {
  display: block;
  background: #000;
}

.block-menu li {
  display: inline-block;
}

.block-menu li a {
  color: #fff;
  display: block;
  text-decoration: none;
  font-family: 'Passion One', Arial, sans-serif;
  font-smoothing: antialiased;
  text-transform: uppercase;
  overflow: visible;
  line-height: 20px;
  font-size: 24px;
  padding: 15px 10px;
}

/* Анимация */
.three-d {
  perspective: 200px;
  transition: all .07s linear;
  position: relative;
  cursor: pointer;
}
  /* Завершение анимации! */
  .three-d:hover .three-d-box, 
  .three-d:focus .three-d-box {
    transform: translateZ(-25px) rotateX(90deg);
  }

.three-d-box {
  transition: all .3s ease-out;
  transform: translatez(-25px);
  transform-style: preserve-3d;
  pointer-events: none;
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
}

/* 
  Помещаем элементы "front" и "back" на место с помощью трансформаций CSS 
*/
.front {
  transform: rotatex(0deg) translatez(25px);
}

.back {
  transform: rotatex(-90deg) translatez(25px);
  color: #ffe7c4;
}

.front, .back {
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: black;
  padding: 15px 10px;
  color: white;
  pointer-events: none;
  box-sizing: border-box;
}


Если у вас есть желание наблюдать, как изменяется передняя ил задняя части, то установите свойство display: none для другой и наведите курсор мыши на меню.

 

Готово!

Никакого JavaScritp или Flash. Просто несколько команд CSS.


Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/UGWIq9RS3v8/lessons.php

Читать комменты и комментировать

Добавить комментарий / отзыв



Защитный код
Обновить

Анимированное меню с 3D эффектом на CSS | | 2012-12-08 02:10:55 | | Статьи Web-мастеру | | В данном уроке мы сделаем простое меню с 3D эффектом при наведении курсора мыши на пункт меню.HTMLСтруктура HTML состоит из списка со ссылками, то есть типовой конструктив для меню навигации. Однако | РэдЛайн, создание сайта, заказать сайт, разработка сайтов, реклама в Интернете, продвижение, маркетинговые исследования, дизайн студия, веб дизайн, раскрутка сайта, создать сайт компании, сделать сайт, создание сайтов, изготовление сайта, обслуживание сайтов, изготовление сайтов, заказать интернет сайт, создать сайт, изготовить сайт, разработка сайта, web студия, создание веб сайта, поддержка сайта, сайт на заказ, сопровождение сайта, дизайн сайта, сайт под ключ, заказ сайта, реклама сайта, хостинг, регистрация доменов, хабаровск, краснодар, москва, комсомольск |
 
Поделиться с друзьями: