जावास्क्रिप्ट तकनीक
लंबन प्रभाव बनाने के लिए, सबसे लोकप्रिय तरीका जावास्क्रिप्ट का उपयोग कर रहा है। इस अध्याय के बाद से हम जावास्क्रिप्ट की अवधारणाओं और कुछ पुस्तकालयों के बारे में चर्चा करेंगे जो लंबन स्क्रॉलिंग को प्राप्त करते हैं।
शुद्ध जावास्क्रिप्ट का उपयोग करने से वेबसाइट के प्रदर्शन को इष्टतम बनाए रखने में मदद मिलती है। प्रदर्शन के एक पहलू से पुस्तकालयों का उपयोग करने के कई अन्य फायदे हैं। हालांकि, कोड संगठन को बेहतर समझने के लिए, हम शुद्ध जावास्क्रिप्ट लंबन कार्यान्वयन के साथ शुरू करेंगे। मजेदार तथ्य, कभी-कभी शुद्ध जावास्क्रिप्ट भी कहा जाता हैvanilla जावास्क्रिप्ट।
शुद्ध जावास्क्रिप्ट का उपयोग करके लंबन स्क्रॉलिंग
सबसे पहले, नीचे दिखाए गए कोड के साथ मुख्य 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);
}
अब जावास्क्रिप्ट हिस्सा आता है, नोटपैड में एक फ़ाइल बनाएं और इसे 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";
}
});
});
कोड का विश्लेषण
आइए जावास्क्रिप्ट कोड का विश्लेषण करते हैं।
से कोड line number 1 to 4 सहायक कार्य का प्रतिनिधित्व करता है।
पंक्ति 6 में, हम अपने लंबन तत्व का चयन करते हैं और जोड़ते हैं scrollखिड़की के लिए घटना। यह निर्धारित करने के लिए कि कितना क्षेत्र स्क्रॉल किया गया है, हम उपयोग कर रहे हैंscrolledHeightसंपत्ति। जैसे ही स्क्रीन स्क्रॉल करती है,backgroundPositionY लंबन तत्व के लिए अद्यतन किया गया है।
लंबन प्रभाव को धीमा करने के लिए, हम 1.5 से विभाजित करते हैं, इस संख्या को आपके इच्छित किसी भी संख्या में बदला जा सकता है।
अब, आप पृष्ठ को नीचे स्क्रीनशॉट में दिए अनुसार स्क्रॉल करते हुए देख पाएंगे।
स्क्रॉलमाजिक जावास्क्रिप्ट लाइब्रेरी का उपयोग करना
जैसा कि पिछले अनुभाग में चर्चा की गई है, जबकि हम लंबन प्रभाव बनाने के लिए शुद्ध जावास्क्रिप्ट का उपयोग कर सकते हैं, कुछ शक्तिशाली जावास्क्रिप्ट पुस्तकालय हैं जो उपयोगकर्ता अनुभव को बढ़ाएंगे। स्क्रॉलमैक्स एक ऐसी लाइब्रेरी है जो लंबन स्क्रॉल इंटरैक्शन बनाने के लिए है।
नीचे दिए गए उदाहरण की सहायता से इसके बारे में अधिक चर्चा करते हैं -
Note- इस उदाहरण में, इसे सरल रखने के लिए, हमारे पास HTML फ़ाइल में संग्रहीत सीएसएस होगा। साथ ही, जावास्क्रिप्ट कोड उसी दस्तावेज में मौजूद होगा। संक्षेप में, हम केवल एक HTML फ़ाइल बनाएंगे और इसमें आवश्यक सीएसएस के साथ स्क्रॉलमैजिक लाइब्रेरी संदर्भित होंगे।
<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 तक की स्क्रिप्ट संदर्भ। सीडीएन का उपयोग करना आधुनिक वेबसाइट विकास में मदद करता है, क्योंकि आपको अपनी वेबसाइट को धीमा किए बिना आवश्यक पुस्तकालयों को लोड करना पड़ता है।
यदि पुस्तकालयों में आवश्यक अनुकूलन हैं, तो इन प्रभावों का उपयोग करने के लिए किसी को अपने संबंधित सर्वर पर पुस्तकालयों की मेजबानी करनी होगी। यदि आप किसी लायब्रेरी से मूलभूत कार्यक्षमताओं का उपयोग कर रहे हैं, तो CDN URL का उपयोग करना कुशल है।
ऊपर दिया गया HTML कोड 2 डिवीजनों द्वारा अलग की गई छवि दिखाता है। प्रथम विभाजन एक शीर्षक के साथ दिखाई देता है -These are bricks और दूसरा विभाजन इसके साथ दिखाई देता है - Some More Bricks।
ध्यान दें कि लाइन 9 से 19 तक सीएसएस कोड में, हम केवल संबंधित लंबन div के लिए स्थिति और शैली निर्दिष्ट कर रहे हैं।
इस सॉफ्ट लंबन को बनाने का काम sceneस्क्रॉलमाजिक लाइब्रेरी द्वारा किया जाता है। यदि आप लाइन 43 से 62 तक स्क्रिप्ट कोड का उल्लेख करते हैं, तो स्क्रॉलमैजिकcontroller आह्वान किया है और ए scene बनाया गया है।
स्क्रीन के 80% हिस्से पर कब्जा करने पर दृश्य लंबन प्रभाव बनाने के लिए DOM को निर्देशित करता है। स्क्रॉल ट्रिगर को समझने के लिए जावास्क्रिप्ट का उपयोग किया जाता है। नतीजतन, आपको जो मिलता है वह इस पृष्ठ पर एक अस्थायी अनुभव है।
Note - छवि को जीआईएफ छवि के रूप में ऊपर देखते हुए, आपको टेक्स्ट डिवीजनों के सुचारू प्रभाव का निरीक्षण करने के लिए नहीं मिलेगा।
ट्रिगर एनिमेशन
स्क्रॉलमाजिक लाइब्रेरी के साथ विविध उपयोगकर्ता अनुभव बनाने की संभावनाएं अनंत हैं। स्क्रॉल पर एनिमेशन को ट्रिगर करने के लिए नीचे दिए गए कोड स्निपेट्स का निरीक्षण करें।
ध्यान दें कि इसके लिए आपको दो फ़ाइलों की आवश्यकता है * माइनस; एक 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>
अब, इसमें निम्न कोड के साथ एक सीएसएस फ़ाइल बनाएं।
.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 कोड का जिक्र करते हुए, स्क्रॉलमाजिक कोड से शुरू होता है line 17 और जारी है line 25। इस खंड में, हम दो स्क्रॉलमाजिक दृश्य बना रहे हैं। पहला दृश्य ईंट की छवि के लिए है और दूसरा बैनर एनीमेशन के लिए है।
में निर्दिष्ट है setTween पर कार्य करते हैं line 20, जब स्क्रॉल कार्रवाई स्क्रीन आकार के 40% पर होती है, तो अगला दृश्य शुरू होता है जो बैनर को दिखाता है यह वह है!
आईडी के साथ div की अस्पष्टता - square सीएसएस फ़ाइल में नियंत्रित किया जाता है line 10 तथा line 15।
परिणामस्वरूप, आपको पृष्ठ पर नीचे एनीमेशन देखने को मिलेगा।
क्षैतिज स्क्रॉलिंग
हम लंबन स्क्रॉलिंग भी लागू कर सकते हैं और एक क्षैतिज स्क्रॉल प्राप्त कर सकते हैं। स्क्रॉलिंग का एक क्षैतिज प्रभाव बनाने के लिए लाइब्रेरी स्क्रॉलमैजिक का उपयोग किया जा सकता है। नीचे दिए गए कोड को देखें।
यद्यपि क्षैतिज स्क्रॉलिंग प्रभाव बनाने के लिए कोड सीधे आगे है, हमें स्क्रीन के क्षैतिज आंदोलन को प्राप्त करने के लिए jquery संदर्भ की आवश्यकता होगी। JQuery का विवरण अगले अध्याय में दिया गया है, अभी के लिए, नीचे दिए गए कोड का पालन करें।
हम तीन अलग-अलग फाइलें बनाएंगे - मुख्य कोड के लिए एचटीएमएल फाइल, स्टाइल के लिए सीएसएस फाइल और स्क्रॉलमैजिक फंक्शन कॉल के लिए जेएस फाइल।
यहाँ 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 की तर्ज पर ids 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, 22 तथा 25।
हम शुरुआत में कोड में प्रत्येक स्क्रीन की सापेक्ष चौड़ाई की गणना कर रहे हैं line 13।
स्क्रॉलमजिक के लिए जावास्क्रिप्ट कोड नीचे दिया गया है -
$(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 हमारी स्क्रीन पर क्षैतिज स्क्रॉल प्रभाव प्रदान करने के लिए जिम्मेदार है।
एक बार संबंधित फाइलें बनाने के बाद, आप नीचे दिखाए गए अनुसार क्षैतिज स्क्रॉल एनीमेशन देख पाएंगे।