Unlimited Plugins, WordPress themes, videos & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Code
  2. Front-End
Code

एक सरल पैरलैक्स स्क्रॉलिंग तकनीक

by
Difficulty:IntermediateLength:LongLanguages:

Hindi (हिंदी) translation by Satyam Sh. (you can also view the original English article)

पैरलैक्स स्क्रॉलिंग एक दिलचस्प तकनीक है, जैसे ही आप स्क्रॉल करते हैं, पृष्ठभूमि छविया अग्रभूमि सामग्री की तुलना में धीमी दिखाई देती है, जिससे 3D गहराई का भ्रम पैदा होता है।  जैसा कि मैंने अपनी निजी वेबसाइट को फिर से डिजाइन करने की योजना बनाई थी, मेरा सबसे पहला लक्ष्य सबसे अधिक अद्भुतता प्राप्त करने के लिए सबसे छोटा और सरल कोड लिखना था! मैं आपको दिखाता हूँ कि मैंने यह कैसे किया।

यदि आप अपने विषय के लिए एक बुनियादी टेम्पलेट के साथ आरंभ करने का एक त्वरित तरीका तलाश रहे हैं, तो एक सरल पैरलैक्स थीम ढूंढना एक अच्छा विकल्प हो सकता है।  या हमारे एक पृष्ठ टेम्पलेट्स के माध्यम से ब्राउज़ करें। आप एनवाटो स्ट्यूडिओ पर सेवा प्रदाता को भी पा सकते हैं जो आपके लिए पैरलैक्स स्क्रॉलिंग साइट बनाएंगे। 

इस ट्यूटोरियल में, मैं आपको सबसे आसान पैरलैक्स स्क्रॉलिंग तकनीक को सिखाऊंगा जो आपने कभी नहीं देखा है, तो हम इसमें प्रवेश करते हैं!


चरण 1: मार्कअप 

यह तकनीक पृष्ठभूमि छवि की गति को नियंत्रित करने के चारों ओर घूमती है। तो हम HTML मार्कअप से शुरू करते हैं, आवश्यक विशेषताओं के साथ दो खंड बनाते हैं: "data-type" और "data-speed"। डोंट वोर्री; मैं ये बाद में समझाऊंगा। 

मैं एट्रिब्यूट data-type और data-speed के साथ <section> टैग का उपयोग कर रहा हूं, जो कि HTML5 में पेश किया गया था। यह HTML मार्कअप क्लीन और पढ़ने में आसान बनाता है। 

कस्टम डेटा विशेषताओं के लिए विनिर्देश (स्पेसफकैशन्ज़) के अनुसार, data- के साथ शुरू होने वाले किसी भी विशेषता को निजी डेटा के लिए एक संग्रहण क्षेत्र माना जाएगा। इसके अतिरिक्त, यह लेआउट या प्रस्तुति को प्रभावित नहीं करेगा। 

चूंकि हमें जो कुछ करना है, पृष्ठभूमि छवियों की गति को नियंत्रित करना है, इसलिए हम आवश्यक पैरामीटर निर्दिष्ट करने के लिए data-type="background" और data-speed="10" कुंजी विशेषताओं का उपयोग करेंगे।

मुझे पता है कि आप क्या सोच रहे हैं: आप IE के बारे में चिंतित हैं। कभी नहीं डरो; मेरे पास इसके लिए एक वैकल्पिक हल भी है! हम इसे क्षणभर चर्चा करेंगे। 

इसके बाद, चलिए प्रत्येक  <section>  में  <article>  टैग के अंदर सामग्री डालते हैं। 

हम जिस चीज को यहाँ करने की कोशिश कर रहे हैं वह है सामग्री, i.e, <article> की तुलना में धीमी गति से <section> पृष्ठभूमि स्क्रॉल करें! इससे हमें एक पैरलैक्स भ्रम बनाने में मदद मिलेगी। jQuery जादू पर जाने से पहले, हम प्रत्येक <section> के लिए हमारे सीएसएस (CSS) में पृष्ठभूमि छवियाँ जोड़ते हैं।

दोनों वर्गों के लिए पृष्ठभूमि (बैक्ग्राउन्ड) जोड़ने पर, यह दिखना चाहिए: 

image
image

चलो कुछ और सीएसएस (CSS) को स्टाइल में जोड़ें और पेज को मसाला दें! 

अब इसे इस तरह दिखना चाहिए ... 

image

चरण 2: जादू कोड 

हां, यह सही है; यह वह जगह है जहां जादू शुरू होता है! jQuery का उपयोग करके, हम मानक document.ready() से शुरू करेंगे यह सुनिश्चित करने के लिए कि पेज लोड हो चुका है और हेरफेर करने के लिए तैयार है।

यह तकनीक पृष्ठभूमि छवि की गति को नियंत्रित करने के चारों ओर घूमती है जो कि दोनों वर्गों में मौजूद है।

अब मुझे आपका ध्यान यहाँ पर चाहिए। नीचे आने वाली पहली बात यह है कि हम पृष्ठ के प्रत्येक  <section>  पर फिर से चल रहे हैं, जिस पर ऐट्रब्यूट  data-type="background"  है। 

किसी अन्य फ़ंक्शन को जोड़ें, .scroll (), अंदर .each (), जिसे उपयोगकर्ता के स्क्रॉलिंग शुरू होने पर लागू किया जाता है। 

हमें यह निर्धारित करने की आवश्यकता है कि उपयोगकर्ता ने कितना स्क्रॉल किया, और फिर मार्कअप में उल्लेखित data-speed वैल्यू के अनुसार मूल्य को विभाजित करें।

$window.scrollTop (): हम शीर्ष से चालू स्क्रॉल मान प्राप्त कर रहे हैं। यह मूल रूप से निर्धारित करता है कि उपयोगकर्ता ने कितनी स्क्रॉल किया है।  $bgobj.data('speed') मार्कअप में निर्दिष्ट data-speed को संदर्भित करता है, और yPos अंतिम मूल्य है जिसे हमें स्क्रॉलिंग के लिए प्रयोग करने की आवश्यकता है।  हालांकि, यह एक नेगटिव मान होगा, क्योंकि हमें पृष्ठभूमि के विपरीत दिशा में उपयोगकर्ता के स्क्रॉल को स्थानांतरित करना होगा। 

एक उदाहरण के साथ थोड़ा और अधिक जांचें: 

image

उपरोक्त छवि में, data-speed 10 है, और मान लीजिए कि ब्राउज़र विंडो में 57px स्क्रॉल किया गया है। इसका मतलब है कि जब 57px को 10 से विभाजित किया जाता है, तो परिणाम 5.7px है। 

आखिरी चीज जो हमें करने की ज़रूरत है वह एक वेरीअबल में हमारे अंतिम पृष्ठभूमि की स्थिति को एक साथ रखनी है। पृष्ठभूमि की क्षैतिज (हॉरिज़ान्टल) स्थिति स्थिर रखने के लिए, हमने 50% को xPosition के रूप में निर्दिष्ट किया है।  फिर, हमने yPos को yPosition के रूप में जोड़ा, और अंत में, हमारे <section> पृष्ठभूमि: $bgobj.css({ backgroundPosition:coords });  को पृष्ठभूमि निर्देशांक निर्दिष्ट किया।

आपका अंतिम कोड ऐसा दिख सकता है: 

याय, हमने यह किया है! इसे स्वयं के लिए प्रयास करें। 


IE Fix

एक अंतिम निदान है: पुराने IE <section> और <article> टैग को प्रस्तुत नहीं कर सकता है। यह ठीक करना आसान है, यद्यपि; हम तत्वों को बनाने के लिए मानक समाधान का उपयोग करेंगे, जिससे ब्राउज़र ने जादुई रूप से HTML5 टैग को पहचान लिया।

साथ ही, हमें सभी ब्राउज़रों को अच्छी तरह से काम करने के लिए मूल सीएसएस रीसेट (CSS reset) फाइल का उपयोग करना होगा। सौभाग्य से, टूल जैसे, एचटीएमएल 5 बॉयलरप्लेट हमारे लिए काम की खामियों का ख्याल रखता है, जब क्रॉस-ब्राउज़र सामान्यकरण की बात आती है।

यह अध्याय के लिए पर्याप्त है! कोई प्रश्न या नोट जो आप जोड़ना चाहते हैं? मुझे नीचे बताओ! 

और अगर आप पेशेवर परिणामों के साथ एक त्वरित समाधान की तलाश कर रहे हैं, तो हमारे पैरलैक्स थीम और एक पृष्ठ टेम्पलेट विकल्पों के माध्यम से / को ब्राउज़ करें, थीमफॉरस्ट (Themeforest) पर खरीदारी के लिए उपलब्ध है।

Advertisement
Advertisement
Advertisement
Advertisement
Looking for something to help kick start your next project?
Envato Market has a range of items for sale to help get you started.