자바 스크립트 기법

Parallax 효과를 만들기 위해 가장 많이 사용되는 방법은 JavaScript를 사용하는 것입니다. 이 장부터 우리는 JavaScript의 개념과 Parallax 스크롤링을 달성하는 데 사용되는 일부 라이브러리에 대해 논의 할 것입니다.

순수한 JavaScript를 사용하는 것은 웹 사이트 성능을 최적으로 유지하는 데 적합합니다. 성능 측면에서 라이브러리를 사용하면 다른 많은 이점이 있습니다. 그러나 코드 구성을 더 잘 이해하기 위해 순수한 JavaScript 패럴 랙스 구현부터 시작하겠습니다. 재미있는 사실은 때때로 순수한 자바 스크립트가vanilla 자바 스크립트.

Pure 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 파일을 하나만 만들고 필요한 CSS와 함께 ScrollMagic 라이브러리를 참조하게됩니다.

<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>

위의 코드에서 볼 수 있듯이 우리는 line 3 to 6. CSS 코드는 9 행에서 19 행까지 지정됩니다.

콘텐츠 전달 네트워크

3 ~ 6 행의 스크립트 참조는 ScrollMagic CDN (Content Delivery Network) URL을 가리 킵니다. CDN을 사용하면 웹 사이트 속도를 늦추지 않고 필요한 라이브러리를로드 할 수 있으므로 최신 웹 사이트 개발에 적합합니다.

라이브러리에 사용자 정의가 필요한 경우 이러한 효과를 활용하려면 해당 서버에서 라이브러리를 호스팅해야합니다. 라이브러리의 기본 기능을 사용하는 경우 CDN URL을 사용하는 것이 효율적입니다.

위의 HTML 코드는 두 부분으로 구분 된 이미지를 보여줍니다. 첫 번째 구분은 제목과 함께 나타납니다.These are bricks 그리고 두 번째 부분은 – Some More Bricks.

9 ~ 19 행의 CSS 코드에서 각 시차 div의 위치와 스타일 만 지정합니다.

이 부드러운 시차를 만드는 작업 sceneScrollMagic 라이브러리에서 수행됩니다. 43 ~ 62 행의 스크립트 코드를 참조하면 ScrollMagiccontroller 호출되고 scene 생성됩니다.

장면은 화면의 80 %가 점유 될 때 시차 효과를 생성하도록 DOM을 안내합니다. JavaScript는 스크롤 트리거를 이해하는 데 사용됩니다. 결과적으로이 페이지에 떠 다니는 경험을 얻을 수 있습니다.

Note − 위의 이미지를 GIF 이미지로 생각하면 텍스트 분할의 부드러운 효과를 볼 수 없습니다.

애니메이션 트리거

ScrollMagic Library로 다양한 사용자 경험을 생성 할 수있는 가능성은 무한합니다. 스크롤시 애니메이션을 트리거하려면 아래 제공된 코드 스 니펫을 관찰하십시오.

이를 위해서는 두 개의 파일 * minus가 필요합니다. 하나의 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 %에서 스크롤 동작이 발생하면 배너가 표시되는 다음 장면이 시작됩니다.

ID가있는 div의 불투명도- square CSS 파일에서 제어됩니다. line 10line 15.

결과적으로 페이지에서 아래 애니메이션을 볼 수 있습니다.

수평 스크롤

시차 스크롤을 적용하고 수평 스크롤을 얻을 수도 있습니다. ScrollMagic 라이브러리를 사용하여 스크롤링의 수평 효과를 만들 수 있습니다. 아래 코드를 참조하십시오.

코드는 수평 스크롤 효과를 만드는 데 간단하지만 화면의 수평 이동을 달성하려면 jquery 참조가 필요합니다. jQuery에 대한 자세한 내용은 다음 장에서 제공됩니다. 지금은 아래 코드를 따르십시오.

메인 코드 용 HTML 파일, 스타일 용 CSS 파일, ScrollMagic 함수 호출 용 JS 파일의 세 가지 개별 파일을 만듭니다.

다음은 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>

스크롤 후 나타나는 세 개의 섹션이 있는지 확인하십시오. 세 섹션은 각각 15, 19 및 23 행에있는 ID title1, title2 및 title3으로 표시됩니다.

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, 2225.

코드에서 각 화면의 상대적 너비를 계산합니다. line 13.

ScrollMagic의 JavaScript 코드는 다음과 같습니다.

$(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이 속성은 사용자가 스크롤 이벤트 완료에 도달 할 때 스크롤 효과를 제공하는 역할을합니다. 함수TimelineMax 화면에 가로 스크롤 효과를 제공하는 역할을합니다.

각 파일을 생성하면 아래와 같이 가로 스크롤 애니메이션을 볼 수 있습니다.