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

CSS ग्रिड (Grid) से ऑफ-कैनवास (Off-Canvas) कैसे बनाये

by
Difficulty:IntermediateLength:ShortLanguages:

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

रेस्पॉन्सिव नेविगेशन को प्राप्त करने के लिए ऑफ-कैनवास (off-canvas) का पैटर्न एक क्लासिक एप्रोच है. जब viewport इतना छोटा हो जाये की इसे वारंट कर सके, तो भारी नेविगेशन "ऑफ-कैनवास" में छुप जाएगा और सिर्फ toggle होने पर ही वापस नजर आएगा.

आज हम ऑफ-कैनवास वाला नेविगेशन बनाएंगे, CSS का प्रयोग करके toggle करेंगे (JavaScript की जरूरत नहीं है) और हमारे अच्छे मित्र Grid का प्रयोग हम पेज के स्ट्रक्चर को बनाने में करेंगे. हम क्या करने वाले हैं, यह उसका फुल पेज डेमो है.

सामान्य सा पेज स्ट्रक्चर

आईये एक सामान्य सा पेज बनाकर शुरू करें; हम कुछ इस प्रकार का बनाना चाहते हैं:

Semantic page structure
अर्थपूर्ण पेज स्ट्रक्चर

यह एक काफी टिपिकल (typical) अर्थपूर्ण (semantic) पेज का स्ट्रक्चर है; आप देखेंगे की छोटे viewports में सभी कुछ एक कॉलम में ही रहेगा, पर बड़ी स्क्रीन पर aside एक तरफ चला जायेगा. <nav> एलिमेंट को नीले रंग से हाईलाइट किया गया है.

यहाँ हमारा मार्कअप है

अब चलो कुछ visual styles और कुछ ग्रिड के नियम जोड़ते हैं.

इसके साथ कुछ Griddy करते हैं

किसी तरह के element में हमारे सभी structural elements को लपेटकर शुरू करें- यह हमारा ग्रिड कंटेनर होगा. मैं <div class="container"></div> का प्रयोग कर रहा हूँ.

अब कुछ बुनियादी ग्रिड styles को जोड़ें:

यहां हम यह declare कर रहे हैं कि कंटेनर को display: grid; होना चाहिए, इसके पास एक fractional यूनिट का एक कॉलम होना चाहिए (इस पॉइंट पर यह बहुत आवश्यक नहीं है, लेकिन इसे पूरी तरह से (thorough) जोड़ दिया गया है), और यह कि सभी ग्रिड items के बीच का अंतर 10px होना चाहिए

इसके बाद चीजें थोड़ी साफ करने के लिए कुछ visual styles को जोड़ दें

इसे Responsive बनाओ

चलो एक मीडिया query जोड़ते हैं, ताकि जब viewport एक निश्चित आकार को हिट करता है (चलो 600px के लिए चलते हैं) layout परिवर्तित होता है.

तो अब, बड़ी स्क्रीन पर, ग्रिड declaration grid-template-column: repeat(4, 1fr); में बदलती है: यह हमें समान चौड़ाई के चार column को देता है, इसलिए हमें यह declare करना होगा कि हम अपने प्रत्येक structural elements को कितना फैलाना चाहते हैं. header, nav और footer सभी 4 में फैले (चार columns में फैले हुए) होंगे, जबकि section सिर्फ तीन ही में span होगा, एक column के गैप को aside के लिए छोड़ेंगे ताकि वह खुद ब खुद भर जाए.

आखिरकार, nav के दिखने के तरीके को बदलने के लिए कुछ styles:

हमारे पास अब तक क्या है:

Venturing Off-Canvas

यह एक सही उदाहरण है कि कैसे CSS positioning अब भी एक घोषित (declared) ग्रिड के भीतर, structural elements पर काम कर सकता है। हम अपने nav को पकड़ने, इसे दस्तावेज़ के प्रवाह से हटाने, और इसे off-canvas की स्थिति में ले जाने के लिए जा रहे हैं. अन्य ग्रिड items ठीक जगह में सही तरीके से प्लेस हो जायेंगे.

अन्य मीडिया query से शुरू करें. हमारे पास पहले से ही हमारी min-width वाली query है, लेकिन इस समय हम केवल एक max-width तक एलिमेंट को स्टाइल देना चाहते हैं। जब तक हमारा viewport मैजिक 600px तक पहुंचता नहीं है, हम चाहते हैं कि nav off-canvas की स्थिति में बने रहें:

हमने nav को एक फिक्स चौड़ाई दी है, इसको पूरी तरह से छिपाने के लिए इसकी पोजीशन जरूरत के हिसाब से लेफ्ट की गयी है. हमने पोजीशन fixed भी की है, हालांकि आप absolute का उपयोग कर सकते हैं यह इस बात पर निर्भर करता है की आप nav को विंडो के साथ स्क्रॉल करना चाहते हैं या नहीं.

आप transition के नियम भी देखेंगे, जो एक बार हमारे toggle कंट्रोल बनाने के बाद प्रभावी होंगे।

Toggling

हमारे nav के गायब होने के बाद, हमें अब जरूरत पड़ने पर इसे वापस लाने के लिए कुछ कंट्रोल की ज़रूरत है। चलो इसे ट्रिगर करने के लिए एक लिंक जोड़ते हैं, और इसे फिर से बंद करने के लिए एक लिंक।

इसे header में जोड़ें

और इसे nav में:

हमें बड़ी स्क्रीन पर दिखाई देने के लिए open लिंक की ज़रूरत नहीं है, इसलिए हम हमारे min-width मीडिया query के भीतर toggle elements को छिपाएंगे:

लक्ष्य

उपरोक्त लिंक्स में क्या महत्वपूर्ण है "fragment identifier" (href में #nav) की उपस्थिति. ये identifier किसी पृष्ठ पर विशिष्ट elements को सीधे नेविगेट करने के लिए ब्राउज़र द्वारा उपयोग किया जाता है. इस मामले में, हम जो भी element id "nav" से मेल खाता है, को लक्षित कर रहे हैं, और एक बार इसे लक्षित किया गया, तो हम इसे :target pseudo क्लास देकर स्टाइल दे सकते हैं. कोई JavaScript आवश्यक नहीं है!

हमारी max-width मीडिया query में निम्न जोड़ें:

बस! यह हमारा toggle है

हमारे पास अब क्या है:

आपको पूर्ण पृष्ठ के डेमो (the full page demo) पर एक नज़र डालने की ज़रूरत है कि यह क्या कर रहा है।

निष्कर्ष

और हम कर चुके हैं! मैंने कम से कम स्टाइल को रखा है ताकि रास्ते में न पड़े, लेकिन पागलपन के लिए खुद को स्वतंत्र महसूस करें और इसे ठीक वैसा ही बनाएं जैसा की आप चाहते हैं.

:target की बजाय, आप JavaScript toggle भी पसंद कर सकते हैं, इस स्थिति में भी आपके पास उस काम को बनाने के लिए सभी कुछ हैं.

मुझे आशा है कि आपने इस छोटे से ग्रिड व्यायाम का आनंद उठाया होगा, इससे अधिक जानने के लिए हमारे साथ बने रहे!

उपयोगी संसाधन

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.