Методы JavaScript
Наиболее популярным методом создания эффекта параллакса является использование JavaScript. Начиная с этой главы, мы будем обсуждать концепции JavaScript и некоторых библиотек, используемых для параллакс-прокрутки.
Использование чистого JavaScript имеет смысл для поддержания оптимальной производительности веб-сайта. Есть много других преимуществ использования библиотек с точки зрения производительности. Однако, чтобы лучше понять организацию кода, мы начнем с чистой реализации параллакса JavaScript. Интересный факт, иногда чистый JavaScript также называютvanilla JavaScript.
Параллаксная прокрутка с использованием чистого JavaScript
Сначала создайте основной файл HTML с кодом, показанным ниже. HTML-страница будет состоять из четырех заголовков.
<html>
<head>
<link rel = "stylesheet" href = "styles.css">
<script src = "myscripts.js"></script>
</head>
<body>
<section class = "parallax">
<h1>The First Scroll</h1>
</section>
<section class = "parallax">
<h1>The Second One</h1>
</section>
<section class = "parallax">
<h1>GoingOn !!</h1>
</section>
<section class = "parallax">
<h1>And we've reached the bottom!!</h1>
</section>
</body>
</html>
Обратите внимание, что в строке 4 в этом примере мы используем myscripts.js файл, который будет храниться в той же папке, что и файл HTML и файл CSS.
Теперь давайте подготовим наш файл CSS, как показано ниже.
header {
height: 4em;
background: #845;
}
.parallax {
background-repeat: no-repeat;
background-size: cover;
}
.parallax h1 {
text-align: center;
margin: 0;
font-size: 2.5em;
letter-spacing: .2em;
color: red;
padding: 10rem 0;
mix-blend-mode: exclusion;
}
.parallax:nth-of-type(1) {
background: url(https://pixabay.com/get/ea35b10621f0083ed1534705fb0938c9bd22ffd41cb2114296f0c679a4/background-3009949_1920.jpg);
}
.parallax:nth-of-type(1) h1 {
padding: 15rem 0;
}
.parallax:nth-of-type(2) {
background: url(https://pixabay.com/get/ea35b10621f0083ed1534705fb0938c9bd22ffd41cb2114296f0c679a4/background-3009949_1920.jpg);
}
.parallax:nth-of-type(2) h1 {
padding: 12rem 0;
}
.parallax:nth-of-type(3) {
background: url(https://pixabay.com/get/ea35b10621f0083ed1534705fb0938c9bd22ffd41cb2114296f0c679a4/background-3009949_1920.jpg);
}
.parallax:nth-of-type(4) {
background: url(https://pixabay.com/get/ea35b10621f0083ed1534705fb0938c9bd22ffd41cb2114296f0c679a4/background-3009949_1920.jpg);
}
Теперь идет часть JavaScript, создайте файл в блокноте и сохраните его как myscripts.js .
function $$(selector, context) {
context = context || document;
var elements = context.querySelectorAll(selector);
return Array.prototype.slice.call(elements);
}
window.addEventListener("scroll", function() {
var scrolledHeight= window.pageYOffset;
$$(".parallax").forEach(function(el,index,array) {
var limit = el.offsetTop+ el.offsetHeight;
if(scrolledHeight > el.offsetTop && scrolledHeight &l;= limit) {
el.style.backgroundPositionY= (scrolledHeight - el.offsetTop) /1.5+ "px";
} else {
el.style.backgroundPositionY= "0";
}
});
});
Анализ кода
Разберем код JavaScript.
Код из line number 1 to 4 представляет вспомогательную функцию.
В строке 6 мы выбираем наш элемент параллакса и добавляем scrollсобытие в окно. Чтобы определить, сколько области прокручивается, мы используемscrolledHeightсвойство. Когда экран прокручивается вниз,backgroundPositionY обновляется для элемента параллакса.
Чтобы замедлить эффект параллакса, мы разделили его на 1,5, это число можно изменить на любое число, которое вы хотите.
Теперь вы сможете увидеть, как страница прокручивается вниз, как показано на скриншоте ниже.
Использование библиотеки ScrollMagic JavaScript
Как обсуждалось в предыдущем разделе, хотя мы можем использовать чистый JavaScript для создания эффекта параллакса, есть несколько мощных библиотек JavaScript, которые улучшат взаимодействие с пользователем. ScrollMagic - одна из таких библиотек для создания взаимодействий параллакс-прокрутки.
Давайте обсудим это подробнее с помощью примера, приведенного ниже -
Note- В этом примере для простоты мы будем хранить CSS в файле HTML. Кроме того, код JavaScript будет присутствовать в том же документе. Вкратце, мы создадим только один HTML-файл, и на него будут ссылаться библиотеки ScrollMagic вместе с требуемым CSS.
<html>
<head>
<script src = "https://cdnjs.cloudflare.com/ajax/libs/gsap/2.0.1/TweenMax.min.js"></script>
<script src = "http://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.5/ScrollMagic.js"></script>
<script src = "http://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.5/plugins/animation.gsap.js"></script>
<script src = "http://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.5/plugins/debug.addIndicators.js"></script>
</head>
<body>
<style type = "text/css">
.parallaxParent {
height: 100vh;
overflow: hidden;
}
.parallaxParent > * {
height: 200%;
position: relative;
top: -100%;
}
</style>
<div class = "spacing0"></div>
<div id = "parallax1" class = "parallaxParent">
<div style = "background-image: url(https://cdn.pixabay.com/photo/2015/05/16/19/13/stones-770264_640.jpg);"></div>
</div>
<div class = "spacing1">
<div style = "background-color:cyan">
<p>These are bricks</p>
</div>
</div>
<div class = "spacing0"></div>
<div id="parallax2" class = "parallaxParent">
<div style = "background-image: url(https://cdn.pixabay.com/photo/2015/05/16/19/13/stones-770264_640.jpg);"></div>
</div>
<div class = "spacing1">
<div style = "background-color:yellow">
<p>Some More Bricks</p>
</div>
</div>
<div class = "spacing0"></div>
<div id = "parallax3" class = "parallaxParent">
<div style = "background-image: url(https://cdn.pixabay.com/photo/2015/05/16/19/13/stones-770264_640.jpg);"></div>
</div>
<div class = "spacing2"></div>
<script>
// init controller
var controller = new ScrollMagic.Controller({
globalSceneOptions: {triggerHook: "onEnter", duration: "200%"}});
// build scenes
new ScrollMagic.Scene({triggerElement: "#parallax1"})
.setTween("#parallax1 > div", {y: "80%", ease: Linear.easeNone})
.addIndicators()
.addTo(controller);
new ScrollMagic.Scene({triggerElement: "#parallax2"})
.setTween("#parallax2 > div", {y: "80%", ease: Linear.easeNone})
.addIndicators()
.addTo(controller);
new ScrollMagic.Scene({triggerElement: "#parallax3"})
.setTween("#parallax3 > div", {y: "80%", ease: Linear.easeNone})
.addIndicators()
.addTo(controller);
</script>
</body>
</html>
Как показано в приведенном выше коде, нам потребовались ссылки на библиотеки JavaScript из line 3 to 6. Код CSS указан в строках с 9 по 19.
Сеть доставки контента
Ссылки сценария со строк 3 по 6 указывают на URL-адреса сети доставки контента (CDN) ScrollMagic. Использование CDN имеет смысл при разработке современных веб-сайтов, поскольку вы можете загружать необходимые библиотеки, не замедляя работу своего веб-сайта.
Если в библиотеках требуются настройки, необходимо разместить библиотеки на соответствующем сервере, чтобы использовать эти эффекты. Если вы используете базовые функции из библиотеки, эффективно использовать URL-адрес CDN.
Приведенный выше HTML-код показывает изображение, разделенное двумя разделами. Первый раздел появляется с заголовком -These are bricks и второе деление появляется с - Some More Bricks.
Обратите внимание, что в CSS-коде строк с 9 по 19 мы указываем только позицию и стиль для соответствующего div с параллаксом.
Работа по созданию этого мягкого параллакса sceneвыполняется библиотекой ScrollMagic. Если вы обратитесь к коду сценария со строк 43 по 62, ScrollMagiccontroller вызывается и scene создано.
Сцены направляют модель DOM для создания эффекта параллакса, когда занято 80% экрана. JavaScript используется для понимания триггера прокрутки. В результате вы получаете плавающий опыт на этой странице.
Note - Рассматривая изображение выше как изображение в формате GIF, вы не заметите плавного эффекта разделения текста.
Триггерные анимации
Возможности создания разнообразного пользовательского опыта безграничны с помощью ScrollMagic Library. Обратите внимание на приведенные ниже фрагменты кода, чтобы запускать анимацию при прокрутке.
Учтите, что для этого вам понадобятся два файла * минус; один файл HTML и один файл CSS.
Создайте HTML-файл с кодом, показанным ниже -
<html>
<head>
<link rel = "stylesheet" href = "style.css">
<script src = "https://cdnjs.cloudflare.com/ajax/libs/gsap/2.0.1/TweenMax.min.js"></script>
<script src = "http://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.5/ScrollMagic.js"></script>
<script src = "http://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.5/plugins/animation.gsap.js"></script>
<script src = "http://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.5/plugins/debug.addIndicators.js"></script>
</head>
<body>
<div class = "spacing0"></div>
<div id = "parallax1" class = "parallaxParent">
<div style = "background-image: url(https://cdn.pixabay.com/photo/2015/05/16/19/13/stones-770264_640.jpg);"></div>
</div>
<div style = "height:450px;"></div>
<div id = "square" class = "square">This is it!</div>
<div style = "height:450px;"></div>
<script>
var controller = new ScrollMagic.Controller();
var scene = new ScrollMagic.Scene({triggerElement: "#parallax1"})
.setTween("#parallax1 > div", {y: "40%", ease: Linear.easeNone})
.addTo(controller);
var scene = new ScrollMagic.Scene({triggerElement: '.square'})
.setClassToggle('.square', 'show')
.addTo(controller);
</script>
</body>
</html>
Теперь создайте файл CSS со следующим кодом.
.square {
background: aqua;
margin: 0 auto;
display: block;
padding: 40px 0;
text-align: center;
color: #000;
font-size: 40px;
font-weight: bold;
opacity: 0;
transition: .3s;
width: 0%;
}
.square.show{
opacity: 1;
width: 100%;
}
.parallaxParent {
height: 100vh;
overflow: hidden;
}
.parallaxParent > * {
height: 200%;
position: relative;
top: -100%;
}
Анализ кода
Что касается HTML-кода, код ScrollMagic начинается с line 17 и продолжается до line 25. В этом разделе мы создаем две сцены ScrollMagic. Первая сцена предназначена для изображения кирпича, а вторая - для анимации баннера.
Как указано в setTween функционировать на line 20, когда действие прокрутки происходит на 40% от размера экрана, начинается следующая сцена, в которой отображается баннер. Вот и все!
Непрозрачность div с идентификатором - square контролируется в файле CSS на line 10 и line 15.
В результате вы увидите на странице приведенную ниже анимацию.
Горизонтальная прокрутка
Мы также можем применить параллаксную прокрутку и добиться горизонтальной прокрутки. Библиотеку ScrollMagic можно использовать для создания горизонтального эффекта прокрутки. См. Код ниже.
Хотя код прост для создания эффекта горизонтальной прокрутки, нам понадобится ссылка jquery для достижения горизонтального перемещения экранов. Подробная информация о jQuery представлена в следующей главе, а пока просто следуйте приведенному ниже коду.
Мы создадим три отдельных файла - HTML-файл для основного кода, CSS-файл для стилей и JS-файл для вызовов функций ScrollMagic.
Вот код для HTML-документа.
<html>
<head>
<link rel = "stylesheet" href = "style.css">
</head>
<script src = 'http://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js'></script>
<script src = 'http://cdnjs.cloudflare.com/ajax/libs/gsap/1.18.0/TweenMax.min.js'></script>
<script src = 'https://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.2/ScrollMagic.min.js'></script>
<script src = 'https://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.2/plugins/animation.gsap.js'></script>
<script src = 'https://cdnjs.cloudflare.com/ajax/libs/ScrollMagic/2.0.2/plugins/debug.addIndicators.min.js'></script>
<script src = "animation.js"></script>
<body>
<div class = "wrapper" id = "js-wrapper">
<div class = "sections" id = "js-slideContainer">
<section class = "section">
<span class = "section__title" id = "title1">Scroll Once</span>
<span id = "trigger--title1"></span>
</section>
<section class = "section">
<span class = "section__title" id = "title2">Do It Again</span>
<span id = "trigger--title2"></span>
</section>
<section class = "section">
<span class = "section__title" id = "title3">Thank You!</span>
<span id = "trigger--title3"></span>
</div>
</div>
</body>
</html>
Обратите внимание, что у нас есть три раздела, которые появятся после прокрутки. Три раздела обозначены идентификаторами title1, title2 и title3 в строках 15, 19 и 23 соответственно.
Код для документа CSS приведен ниже -
body {
font-family: serif;
}
body, html {
height: 100%;
}
.wrapper {
width: 100%;
height: 100%;
overflow: hidden;
}
.section {
height: 100%;
width: calc( 100% / 5 );
float: left;
position: relative;
}
.section:nth-child(1) {
background: green;
}
.section:nth-child(2) {
background: orange;
}
.section:nth-child(3) {
background: red;
}
.sections {
width: 500%;
height: 100%;
}
.section__title {
position: absolute;
top: 50%;
left: 50%;
font-size: 30px;
color: #fff;
}
Анализ кода
Цвета фона для трех экранов (или разделов) представлены на lines 10, 22 и 25.
Мы вычисляем относительную ширину каждого экрана в коде, начиная с line 13.
Код JavaScript для ScrollMagic приведен ниже -
$(function () {
var controller = new ScrollMagic.Controller();
var horizontalSlide = new TimelineMax()
.to("#js-slideContainer", 1, {x: "-20%"})
.to("#js-slideContainer", 1, {x: "-40%"})
new ScrollMagic.Scene({
triggerElement: "#js-wrapper",
triggerHook: "onLeave",
duration: "400%"
})
.setPin("#js-wrapper")
.setTween(horizontalSlide)
.addTo(controller);
});
Обратите внимание на triggerHookсвойство в строке 8. Это свойство отвечает за обеспечение эффекта прокрутки, когда пользователь достигает завершения события прокрутки. ФункцияTimelineMax отвечает за обеспечение эффекта горизонтальной прокрутки на наших экранах.
После создания соответствующих файлов вы сможете увидеть анимацию горизонтальной прокрутки, как показано ниже.