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

सिंपल रेस्पॉन्सिव ग्रिड, सैस के साथ भी बेहतर बनाया गया

by
Difficulty:IntermediateLength:MediumLanguages:

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

इस ट्यूटोरियल में हम CSS का इस्तेमाल करते हुए एक सिंपल, रेस्पॉन्सिव ग्रिड प्रणाली बनाने जा रहे हैं। एक बार जब हम परिचित होते हैं, तो यह कैसे काम करता है, हम इसे सैस के साथ बेहतर बनाते हैं, रास्ते में कुछ प्रमुख सैस सुविधाओं को सीखते हैं।

CSS के साथ आरंभ करना

चलो जल्दी से जाचे क्या हमारे ग्रिड प्रणाली की तरह दिखेगा। बिल्डिंग ग्रिड्स के तेज तरीके हैं, जिनको मार्कअप पर कम दखल की आवश्यकता है, लेकिन यह ग्रिड हमें सरल, अभी तक उपयोगी Sass तकनीकों का अभ्यास करने का एक शानदार अवसर देती है। यह एक रैपिंग एलिमेंट्स का उपयोग करता है, फिर उसमें अन्य एलिमेंट जो पंक्तियों के रूप में कार्य करते हैं, फिर उन तत्वों के भीतर जो हमारे स्तंभों के रूप में कार्य करते हैं।

थोड़ा सा ट्रिपी, लेकिन आपको यह विचार मिलता है ..

Grid.css

आरंभ करने के लिए, हमें बस एक CSS फ़ाइल की आवश्यकता है, इसलिए अपने कोड एडिटर में एक नया दस्तावेज़ खोलें और इसे "grid.css" नाम दें।

सबसे पहले जो हम जोड़ना चाहते हैं वह एक ग्लोबल रीसेट और बॉक्स-साइजिंग नियम है। इससे यह सुनिश्चित होगा कि हमारे तत्वों पर लागू पैडिंग को गणना की गई आयामों के भीतर जोड़ दिया गया है, जिससे हमें स्तंभ चौड़ाई को परिभाषित करने के लिए अधिक से अधिक आजादी मिलेगी।

इसके बाद हम यह सुनिश्चित करने के लिए एक नियम जोड़ देंगे कि किसी भी इमेजेज का उपयोग द्रव-रूप से किया जाता है।

रैपर

अब कुछ नियम यह सुनिश्चित करने के लिए हैं कि हमारा रेपर एलिमेंट स्वयं व्यवहार करता है।

नोट: ध्यान रखें कि हम पहले मोबाइल पर काम कर रहे हैं।  हमारा कंटेनर 100% व्यूपोर्ट की चौड़ाई से शुरू होता है, लेकिन हम इसे बड़ी स्क्रीन के लिए बदल देंगे।

पंक्तियाँ

हमारे सभी पंक्ति एलिमेंट्स में कॉलम होते हैं, जिससे यह सुनिश्चित होता है कि कॉलम के समूह एक दूसरे को ठीक से साफ़ करते हैं। चलिए कुछ सामान्य .clearfix जोड़ते है हमारे रेपर और पंक्ति एलिमेंट्स के लिए।

नोट: हमें इन एलिमेंट्स का नाम नहीं देना है। .wrapper, .row और .column, हम उससे अधिक रचनात्मक हो सकते हैं। ये नाम इस ट्यूटोरियल के प्रयोजनों के लिए बहुत स्पष्ट हैं।

कॉलम

प्रत्येक स्तंभ के आकार के आधार पर, हम कॉलम classes की एक श्रृंखला रखते हैं (उदाहरण के लिए .column-1 और .column-6 आइए, एक ही चयन में इन सभी को लक्ष्य और शैली के लिए एक विशेषता चयनकर्ता का उपयोग करें।

यह चयनकर्ता कहता है; किसी भी एलिमेंट को लो, जिसकी class में स्ट्रिंग column- शामिल हैं और निम्न स्टाइल्स को लागू करें। इसलिए हमारे सभी स्तंभ तत्वों को छोड़ दिया जाएगा, 1em का एक पैडिंग होगा (यह हमारे गटर और कुछ वर्टीकल जगह बनाता है) और व्यूपोर्ट की चौड़ाई का 100% भर जाएगा (फिर से, हम पहले यहां मोबाइल पर काम कर रहे हैं)। अंत में, min-height: 1px सुनिश्चित करता है कि कॉलम ठीक से प्रदर्शित करता है, भले ही इसमें कोई सामग्री न हो।

मानो या न मानो, अब हमारे पास एक ग्रिड है! मार्कअप हम सभी की जरूरत है।

हम पंक्तियों के भीतर कॉलम के किसी भी संयोजन का उपयोग कर सकते हैं, यह देखने के लिए डेमो पर नज़र डालें कि आपको वर्तमान में क्या करना चाहिए।

यह स्क्रीनशॉट ऊपर स्निपेट के मुकाबले अधिक से अधिक कॉलम दिखाता है

रेस्पॉन्सिव जा रहे हैं

यह हमारे मोबाइल दृश्य का ध्यान रखा गया है, अब हमें बड़ी स्क्रीन के लिए एक अलग लेआउट देने के लिए एक मीडिया क्वेरी जोड़ें। आपको अपने खुद के ग्रिड के लिए ब्रेकपॉइंट निर्धारित करने की आवश्यकता होगी, लेकिन हम 30em के एक अनियंत्रित ब्रेकपॉइंट का उपयोग करने जा रहे हैं।

इस मीडिया क्वेरी के भीतर आने वाली कोई भी स्टाइल 30em के स्क्रीन पर और अधिक व्यापक हो जाएगी। हम अपने कॉलम को सही चौड़ाई में विभाजित करने के लिए इस बिंदु का उपयोग करेंगे।

% चौड़ाई

प्रत्येक स्तंभ कितने चौड़ा होना चाहिए? यह हमारे कॉलम पर निर्भर करता है। इस प्रदर्शन के लिए मैं बारह स्तंभों के साथ काम कर रहा हूं, इसलिए हर एक को आवरण का एक बारहवीं (1/12) होना चाहिए। एक कॉलम के लिए जो दो चौड़ाई फैलाती है, यह दो बारहवीं होगी, और इसी तरह। ये जो हमें देता है वह है:

आप यह भी देखेंगे कि हमने स्क्रीन के पूर्ण चौड़ाई से कम .wrapper एलिमेंट बना लिया है और इसे max-width दिया है। देखो कि हमारे ग्रिड के लिए क्या किया है।

आप शायद अपनी खुद की ग्रिड में और अधिक उचित पैडिंग चुनना चाहेंगे

Sass के साथ चीजों को साफ करना

हमारा CSS ग्रिड काम करता है, लेकिन अगर हम वास्तव में हमारे ग्रिड में सोलह कॉलम चाहते हैं तो क्या होगा? या इससे भी ज्यादा? हमें हर कॉलम की फिर से गणना करना होगा और मैन्युअल रूप से इसे प्रत्येक बार हमारे CSS फ़ाइल में दर्ज करना होगा। यह न बताएं कि हमारे CSS को लंबे समय तक और लंबे समय तक और प्रबंधित करने में अधिक कठिन हो जाएगा। खुशी से, Sass (या कोई अन्य पूर्वप्रोसेसर) हमारी मदद कर सकता है।

Sass सेट करना

यह ट्यूटोरियल Sass को स्थापित करने के बारे में नहीं है, यह मानता है कि आप पहले से जानते हैं कि यह कैसे करना है। यदि यह मामला नहीं है और आपको चीजों को उठाने और चलाने की आवश्यकता है, तो एक नज़र डालें: Mastering Sass: Lesson 1 SASS पर और  SASS and Compass for Web Designers: Introduction

आपके पास एक सैस प्रोजेक्ट सेटअप हो जाने के बाद, अगले चरण में डुबकी लगाए।

डेफिनिंग वेरिएबल्स

सैस हमें अपने CSS को सभी प्रकार के तरीकों को साफ करने में मदद करने जा रहा है, लेकिन पहली चीज जो हम कर सकते हैं वह किसी उपयोगी मूल्य को निकालती है और उन्हें वेरिएबल्स में संग्रहीत करती है। "_variables.scss" नामक एक नया आंशिक रूप से शुरू करना शुरू करें; एक सैस फाइल जो सीधे CSS में संकलित नहीं की जाएगी, लेकिन हम अपनी अन्य फाइलों में संदर्भ लेंगे।

ये वैरिएबल हमें उन कॉलम की मात्रा देते हैं जिनके साथ हम काम करना चाहते हैं; 12 इस समय, लेकिन आसानी से 16, शायद 32 (जो भी आप वास्तव में चाहते हैं) में बदला जा सकता है। हमने स्ट्रिंग के रूप में वेरिएबल्स में कुछ ब्रेकपॉइंट्स को भी संग्रहित किया है, भले ही हम इस समय केवल एक का उपयोग कर रहे हैं।

हम इन्हें शीघ्र ही उपयोग करेंगे, लेकिन पहले हम कुछ मिक्सिक्स सेटअप करेंगे।

mixins

सैस मिक्सिक्स कोड का हिस्सा हैं, जिसे हम एक बार परिभाषित कर सकते हैं और फिर हमारे प्रोजेक्ट में कहीं और उपयोग कर सकते हैं। उदाहरण के लिए, हम पहले नियमों का पहला सेट ले सकते हैं जहां हम border-box बोर्ड सेटअप करते हैं और इनमें से अधिकतर एक मिक्सिन में निकाले जाते हैं। हम शुरू करते हैं:

फिर हम इसे का एक हिस्सा निकालते हैं जिसे हम पुन: उपयोग कर सकते हैं, एक मिक्सिन परिभाषित कर सकते हैं जिसे मैंने "border-box" कहा है जैसे:

इसके बाद, हम @import  हमारे वेरिएबल्स और मिक्सिन को मुख्य "grid.scss"। @include स्टेटमेंट के साथ मिक्सिन का उपयोग करके।

@extend Clearfix

हम स्पष्ट रूप से नियमों के साथ ऐसा ही कर सकते हैं, जैसा कि  suggested by Sebastian Ekström किया गया है। इस मामले में हम Nicolas Gallagher द्वारा सुझाए गए क्लेयरफॉक्स नियम लेते हैं और उन्हें placeholder selector (%) के साथ हमारे मिक्सिन फ़ाइल में जोड़ते हैं:

प्लेसहोल्डर चयनकर्ता हमें शैली के पूरे खंड को परिभाषित करने की अनुमति देता है जो केवल आउटपुट प्राप्त करते हैं जब हम उन्हें कहीं और बढ़ाते हैं, जैसे:

एक बार संकलित होने के बाद, Sass की साफ कुछ लाइनें इस तरह दिखती हैं:

हमारे वेरिएबल का उपयोग करना

चलो हम उन वेरिएबल्स के कुछ सेट अप करते हैं, जो हम करेंगे? शुरू करने के लिए हम आवरण पर max-width मूल्य को स्वैप कर सकते हैं। इस:

यह हो जाता है:

अब हमारे मीडिया क्वेरी के साथ ऐसा ही करते हैं। इस:

हमारे $breakpoint-medium वेरिएबल से बेहतर होगा:

नोट: आप देखेंगे कि हम #{} में हमारी वैरिएबल को व्राप्पेड करते हैं। इसे interpolation के रूप में जाना जाता है। यह आम तौर पर किया जाता है यदि हमें किसी अन्य के भीतर एक वेरिएबल का उत्पादन करना पड़ता है, लेकिन इस मामले में यह आवश्यक है क्योंकि मीडिया मीडिया पर होने वाले सैस कंपाइलर का दौरा संभव है यदि @media सीधे ब्रेसिज़ ()। आप इसके बारे में अधिक पढ़ सकते हैं ह्यूगो गिरादुले के ऑल यू ओवर सॉवर एज़ नॉव एस जानना सैस इंटरपोलेशन

हमारे अंतिम वैरिएबल, $grid-columns का उपयोग करने के लिए, हमें कुछ और Sass कार्यक्षमता का उपयोग करने की आवश्यकता है; लूप।

Sass Loops

हमारे कॉलम की चौड़ाई परिभाषाएं वास्तव में समान हैं, वास्तविक मूल्यों के अलावा। अगर हम जरूरत के हिसाब से कई कॉलम के लिए कॉलम की परिभाषा को आउट करते हैं, तो हर बार मूल्य बदलते वक्त यह बहुत साफ हो जाएगा। ऐसा करने के लिए हम Sass @for लूप का उपयोग कर सकते हैं, जो इस तरह दिखता है:

यह 12 पुनरावृत्तियों पर लूप होगा, और प्रत्येक बार $i का मूल्य उस लूप को प्रतिबिंबित करेगा। हम $i इस तरह से उत्पादन कर सकते हैं:

दोबारा, आप देखेंगे कि हम ${} के आसपास $i को एक स्ट्रिंग के रूप में आउटपुट का उपयोग कर रहे हैं जो हम .column- selector. यह संकलित करते समय हमें निम्नलिखित देता है:

प्रतिभाशाली! अब इन चयनकर्ताओं के भीतर सही शैली का उत्पादन करने के लिए कुछ गणना का उपयोग करें।

सैस ऑपरेटर्स

हम अच्छी तरह से कर रहे हैं, लेकिन अब हमें प्रत्येक चयनकर्ता के लिए निम्नलिखित की तरह कुछ आउटपुट चाहिए:

उस स्तंभ की चौड़ाई को 100% के रूप में गणना की जाती है, कॉलम की कुल संख्या से विभाजित, कॉलम संख्या से गुणा किया जाता है। इस मामले में 100% / 12 * 5 = 41.66667%। इसलिए हम लागू करने की आवश्यकता वाली गणना, वेरिएबल्स के लिए प्रासंगिक मानों को बदलना।

सैस अब हमारे लिए गणना कर रहा है, हमें निम्न दे:

टिडिंग के अंतिम बिट के रूप में, हम मूल्य 12 के बजाय $grid-columns वैरिएबल का उपयोग कर सकते हैं:

अब, यदि हम कॉलम की संख्या बदलना चाहते हैं, तो हम केवल वेरिएबल को बदलते हैं और गणना हमारे लिए पूरी हो जाएगी! उदाहरण के लिए, $grid-columns को 4 में बदलकर हमें निम्न CSS दें:

निष्कर्ष

हमारी अंतिम ग्रिड.scss एक मात्र 42 लाइन कोड है; हमारे प्रारंभिक CSS से कम तरह से।

इस प्रक्रिया के दौरान हमने सैस वेरिएबल्स, मिक्सिक्स, प्लेसहोल्डर्स, एक्सटेंड, लूप, ऑपरेटर और यहां तक कि इन्टरपोलेशन भी देखा है। यह सुविधाओं का एक अविश्वसनीय रूप से शक्तिशाली सेट और एक शानदार शुरुआत है, यदि आप बस Sass में मिल रहे हैं।

हमारे द्वारा बनाए गए ग्रिड में आप और सुधार कैसे कर सकते हैं? आप और क्या जोड़ेंगे या निकालेंगे? हमें टिप्पणियों में बताएं!

आगे की पढाई

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.