Unlimited Wordpress themes, plugins, graphics & courses! Unlimited asset downloads! From $16.50/m
Advertisement
  1. Web Design
  2. Complete Websites
Webdesign

रेस्पॉन्सिव Timeline पोर्टफोलियो पेज कैसे समाप्त करें।

by
Difficulty:IntermediateLength:ShortLanguages:
This post is part of a series called Design and Build a Responsive Timeline Portfolio Page.
Building the Responsive Timeline Portfolio Page

Hindi (हिंदी) translation by Ashish Rampal (you can also view the original English article)

Final product image
What You'll Be Creating

पिछले ट्यूटोरियल से आगे बढ़ते हुए, आइए अपने निर्माण को थोड़ा बढ़ाए।

Loading Icon

हम CSS3 एनिमेशन में तल्लीन करने जा रहे हैं और हमारे लोडिंग आइकन के लिए एक सरल स्पिनिंग एनीमेशन बनाते हैं। हमारे पास पेज पर पहले से ही मार्कअप है जिसकी ज़रूरत है, तो CSS में सीधे आइये।

हमारे Sass फ़ाइल में portfolio-item ब्लॉक के बाद यह कोड रखें। इसके साथ शुरू करने के लिए, यहां हम लोड करने वाले div के लिए कुछ स्टाइल स्थापित कर रहे हैं। हम इसे absolute पोजीशन कर रहे हैं और सुनिश्चित कर रहे हैं कि यह एक margin-left -50px का उपयोग करके केंद्रित होता है, जो एलिमेंट की चौड़ाई का आधा हिस्सा है। यह CSS पोसिशन्स के ऊपरी बाएं कोने से एलिमेंट्स के लिए तैयार करने के लिए है।

अगला सेक्शन और भी दिलचस्प होगा। जैसा कि आपने HTML में देखा होगा हमने लोडिंग <img> टैग पर rotate क्लास को असाइन किया है, जिसे हम CSS एनीमेशन प्रदर्शन करने के लिए हुक के रूप में उपयोग करेंगे। यहां स्टाइल्स हमारे एनीमेशन के लिए सेट की गई हैं।

हम मूल रूप से CSS को बता रहे हैं कि हमारे एनीमेशन फंक्शन को क्या कहा जाता है (हम इसे एक पल में बनाएंगे), कितनी देर तक एनीमेशन चलाना चाहिए, कितनी बार चलाना चाहिए और उपयोग करने के लिए timing या easing फंक्शन के प्रयोग करना है। हमारी परियोजना (project) के लिए हम एक अच्छा स्मूथ 360 डिग्री रोटेशन चाहते हैं जो कभी भी बंद न हो। उपरोक्त कोड ठीक वही प्राप्त करेगा।

नोट: हमें ब्राउज़र की प्रीफ़िक्स्ड डेक्लरेशंस को शामिल करना होगा ताकि कोई भी यह भूल ना जाए - और हम हमारे लिए भारी भार उठाने के लिए एक Sass mixin का उपयोग करके इसे बेहतर कर सकते हैं।

चलो ब्राउज़र में एक नज़र डालें।

ठीक है, यह वास्तव में अच्छा लग रहा है, लेकिन एक बात मिसिंग है। यह एनिमेट नहीं हो रहा! चलिए यह फिक्स करते हैं निम्न कोड के साथ:

तो यहाँ rotate फ़ंक्शन है। जिस तरह से यह काम करता है, वह एलिमेंट बदलने के लिए एनीमेशन में महत्वपूर्ण बिंदुओं को सेट कर रहा है। आप 0%, 25%, 50% और इसी तरह से, पर कुछ होने के लिए कुछ सेट कर सकते हैं। हमारा एनीमेशन बहुत सरल है, इसलिए हमें 100% पर एक डिक्लेरेशन की आवश्यकता है, जिसमें बताता है कि एलिमेंट 360 डिग्री तक घुमाया जाना चाहिए। इसका मतलब यह है कि हमारा एलिमेंट पूरे स्पिन का प्रदर्शन करेगा और वापस शुरू करेगा जहां वह शुरू होगा। हमारा पहला सेटअप सुनिश्चित करता है कि यह अनिश्चित काल तक जारी रहेगा। transform-origin प्रॉपर्टी CSS को कहती है की कहाँ एनीमेशन के लिए केंद्र बिंदु है। हम इसे केंद्र के शीर्ष बाएं कोने से स्पिन करने के लिए सेट कर सकते हैं (जो दिलचस्प लग सकता है!), लेकिन हम यहां हमारे एलिमेंट का सही केंद्र का उपयोग करना चाहते हैं। इस फाइल को सेव करें और ब्राउज़र में एक नज़र डालें!

यह उपरोक्त के समान दिखना चाहिए, लेकिन बहुत स्मूथ और तेज।

यह हमारे टाइमलाइन पोर्टफोलियो पेज को तैयार करता है, लेकिन एक बात हम इस ट्यूटोरियल के purposes के लिए जोड़ सकते हैं।

Loading Content

अब, वास्तविक दुनिया में इस प्रकार की लेआउट/थीम में शायद कुछ प्रकार की अनंत स्क्रॉल फीचर होता है, जहां अधिक आइटम दिखाई देते हैं, जैसे ही आप पृष्ठ को स्क्रॉल करते हैं, आपको पृष्ठों के माध्यम से जाने के लिए क्लिक करने से रोकता है।

हम यहां jQuery के कुछ लाइनों के साथ इस बेहेवियर को अनुकरण (simulate) कर सकते हैं। ऊपर app.js खोलें और निम्नलिखित को जोड़कर शुरू करें, जहां ऊपर हमने हमारा मेनू शीर्षक क्लिक हैंडलर लिखा था।

सबसे पहले हमें दो वेरिएबल्स घोषित करने की जरूरत है जो हम बाद में उपयोग कर सकते हैं। दूसरा एक विशुद्ध रूप से एक डिक्लेरेशन है और उसे बाद में एक वैल्यू दी जायेगी। पहला, visibleHeight, window की हाइट को पकड़ लेते है और समग्र document की ऊंचाई से उसको घटा देता है। यह हमें उस क्षेत्र की ऊंचाई के साथ छोड़ देगा जो वर्तमान में यूजर के ब्राउज़र में दिखाई दे रहा है।

अगला, उपर्युक्त स्निपेट (snippet) जोड़ें। आप फ़ंक्शन के कुछ फ़ंक्शन कॉल्स देखेंगे जो अभी तक मौजूद नहीं हैं, जो ठीक है क्योंकि हम उन्हें अगले बना देंगे।

storeElements फ़ंक्शन हमारे DOM एलिमेंट्स के साथ हमारे items वैरिएबल को पॉप्युलेट करने का एक तरीका के रूप में कार्य करता है। हमारे मामले में हम पहले तीन portfolio-items को पकड़ना चाहते हैं। JQuery के lt() का उपयोग हमें चुनिंदा elements को चुनने देता है जो हम चाहते हैं। हमारे पास सिलेक्शन होने के बाद हमे उन्हें clone() करना चाहिए, इसलिए हम वास्तविक एलिमेंट्स का उपयोग नहीं कर रहे हैं, बल्कि इसके बजाय एक कॉपी का उपयोग कर रहे हैं। अंतिम चरण यह है कि first क्लास को रिमूव कर दें यदि पहले से मौजूद है, क्योंकि हमारे नए एलिमेंट्स में से कोई भी सूची में सबसे पहले नहीं है।

इस फंक्शन को storeElements से ऊपर रखें। यह संभवतः सरल कार्य है क्योंकि यह केवल document ready करने पर किया गया है। इसके कारण मैंने ऐसा करने के लिए फ़ंक्शन का उपयोग किया है, इसे पुन: reusable रखने के लिए।

अब हम उस फंक्शन में जाते हैं जो काम कर रहा है...

ठीक है, हम यहाँ क्या कर रहे हैं पर कदम से कदम देखते हैं:

  • जांचें कि क्या स्क्रॉल की position (scrolled past) से अधिक है या (वर्तमान में) visibleHeight के बराबर है।
  • यदि ऐसा है, तो window से स्क्रॉल ईवेंट हैंडलर निकालें ताकि हम कंटेंट को प्रोसेस कर सकें।
  • बाद में उपयोग के लिए loading-wrap को Cache करें।
  • loading-wrap fade in होता है और एक बार fade पूर्ण हो जाता है...
  • ...कंटेंट लोड करने के लिए "loading" अनुकरण करने के लिए एक छोटा Timeout सेट करें।
  • loading-wrap से पहले हमारे क्लोन items को अटैच करें। यह लोडिंग आइकन और वर्तमान portfolio-items के बीच अच्छी तरह से स्लॉट करेगा।
  • loading-wrap को हाईड करें और एक बार चुप जाए तो updateHeight करें, storeElements करें और फिर स्क्रॉल ईवेंट को इस फ़ंक्शन को चलाने के लिए निर्देशों के साथ window में पुन: संलग्न करें।

ओह! ऐसा लगता है कि बहुत कुछ है, तो फिर इसे फिर से चलाएं अगर आप को जरूरत है। एक बात जो आप नोटिस कर सकते हैं, यदि आपकी आंखें चील की तरह तेज हैं, कि हम loading-wrap में fade हो रहे हैं जो वास्तव में पहले से ही हमारे HTML में दिखाई दे रहा है। उस एलिमेंट को एक इनलाइन स्टाइल जोड़कर ठीक करें...

इसलिए, अगर हम अब अपनी फाइलों को सेव करते हैं और ब्राउज़र में हमारा काम देखते हैं तो आपको पृष्ठ के निचले हिस्से में स्क्रॉल करने के बाद कुछ और कंटेंट "load" दिखने चाहिए। ओह रुको, एक और चीज है जिसे हमें जोड़ने की आवश्यकता है...

हम बिलकुल शुरूआत में किए गए h3 क्लिक हैंन्डलर के अंदर हमें कॉल updateHeight() में जोड़ना होगा, इस तरह जब हम एक मेनू खोलने के लिए क्लिक करेंगे तो डॉक्यूमेंट की ऊंचाई में बदलाव को दर्शाने के लिए वेरिएबल अपडेट किए जाते हैं। इसके बिना, यदि आप मोबाइल पर एक मेनू खोलते हैं तो "loading" functionality को तोड़ा जाएगा क्योंकि visibleHeight  वेरिएबल गलत होगा।

Conclusion

हम अंत तक पहुँच चुके हैं! हम शायद हमारे द्वारा लिखे गए जावास्क्रिप्ट को व्यवस्थित कर सकते हैं और, वास्तविक स्थिति में यह संभवतः एक AJAX कॉल या कुछ और में बदल जाएगी।

मुझे आशा है कि आपने इस ट्यूटोरियल के साथ कुछ अलग अलग तकनीकें सीख ली हैं। यह बनाना मज़ेदार था और मैं आपके साथ इस जीवन में बहुत अच्छी डिजाइन लाने की प्रक्रिया को साझा करने में प्रसन्न हूं। मुझे यकीन है कि इसमें सुधार करने के कई तरीके हैं, इसलिए यदि आपके पास कोई सुझाव हैं तो कृपया मुझे कमैंट्स में बताएं!

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.