Я уверен, что вы часто видели на различных веб-сайтах необычные эффекты при переходе между страницами, большинство из них создавалось с помощью JavaScript. В этом уроке я покажу, как вы можете создать свой собственный эфект перехода, но вместо JavaScript я буду использовать CSS Transition и свойство :target.
HTML будет состоять из пяти основных секций: заголовок и содержание четырех разделов. Каждый из разделов содержания будет иметь свой ID и класс panel. Кроме того, мы добавим еще один раздел, который будет внутри основных четырех разделов, и будет иметь класс content. Первая секция с ID #home будет иметь только класс content, и не будет содержать дополнительный блок внутри:
В секции #header у нас будет основной заголовок и навигация:
<!-- Header with Navigation --> <divid="header"> <h1>Page Transitions with CSS3</h1> <ulid="navigation"> <li><aid="link-home"href="#home">Home</a></li> <li><aid="link-portfolio"href="#portfolio">Portfolio</a></li> <li><aid="link-about"href="#about">About Me</a></li> <li><aid="link-contact"href="#contact">Contact</a></li> </ul> </div>
Теперь, основная идея заключается в использовании псевдо-класса :target для того, чтобы добавить переход на текущий раздел. В этом примере мы будем "перелистывать" наши страницы сначала вверх, а затем вниз (см. первый демо-пример).
CSS
Первым делом мы зададим стили нашему заголовку и навигации. Мы хотим, чтобы они были на одном и том же месте, в любое время, даже если всё остальное будет двигаться.
Все разделы, кроме #home, имеют класс panel. Здесь мы будем использовать переход всякий раз, когда элемент c этим классом вызывается в меню. Трюк заключается в использовании отрицательного отступа в классе panel в "обычном" состоянии и отсутствии этого отступа у этого класса при использовании псевдо-класса :target. Переход создает эффект выезда страницы сверху:
.panel{ min-width:100%; height:98%;
overflow-y:auto;
overflow-x:hidden; margin-top:-150%; position:absolute; background:#000;
box-shadow:0px4px7px rgba(0,0,0,0.6); z-index:2;
-webkit-transition: all .8s ease-in-out;
-moz-transition: all .8s ease-in-out;
-o-transition: all .8s ease-in-out;
transition: all .8s ease-in-out; } .panel:target{ margin-top:0%; background-color:#ffcb00; }
Далее зададим стили для класса content, который есть во всех наших секциях:
Для того чтобы изменить цвет текущего элемента в навигации, мы будем использовать псевдо-класс :target с обобщенным родственным комбинатором (the general sibling selector), чтобы "найти" соответствующий пункт навигации: