सीएसएस की एक लाइन में 10 नए लेआउट

आधुनिक सीएसएस लेआउट की मदद से, डेवलपर कुछ ही कीस्ट्रोक में स्टाइल के सटीक और बेहतर नियम लिख सकते हैं. ऊपर दी गई बातचीत और इस पोस्ट में, सीएसएस की 10 ऐसी लाइनें देखी गई हैं जो काफ़ी काम की हैं.

इन डेमो को खुद आज़माने या इनके बारे में जानने के लिए, ऊपर दिए गए Glitch एम्बेड को देखें या 1linelayouts.glitch.me पर जाएं.

1 सुपर सेंटर: place-items: center

पहले 'सिंगल-लाइन' लेआउट के लिए, सीएसएस की दुनिया की सबसे बड़ी पहेली को हल करते हैं: चीज़ों को बीच में रखना. हम आपको बताना चाहते हैं कि place-items: center की मदद से, यह काम आपकी सोच से ज़्यादा आसान है.

सबसे पहले, display के तौर पर grid तय करें. इसके बाद, उसी एलिमेंट पर place-items: center लिखें. place-items, align-items और justify-items, दोनों को एक साथ सेट करने के लिए शॉर्टहैंड है. इसे center पर सेट करने पर, align-items और justify-items, दोनों center पर सेट हो जाते हैं.

.parent {
  display: grid;
  place-items: center;
}

इससे, कॉन्टेंट को पैरंट में सही तरीके से सेंटर किया जा सकता है. इस बात से कोई फ़र्क़ नहीं पड़ता कि कॉन्टेंट का साइज़ कितना है.

02. The Deconstructed Pancake: flex: <grow> <shrink> <baseWidth>

अगला वीडियो, डिसकंस्ट्रक्टेड पैनकेक का है! यह मार्केटिंग साइटों के लिए एक सामान्य लेआउट है. उदाहरण के लिए, इसमें तीन आइटम की एक लाइन हो सकती है. आम तौर पर, इसमें एक इमेज, टाइटल, और फिर कुछ टेक्स्ट होता है, जिसमें किसी प्रॉडक्ट की कुछ सुविधाओं के बारे में बताया जाता है. हम चाहते हैं कि मोबाइल पर ये आइटम अच्छी तरह से स्टैक हों और स्क्रीन साइज़ बढ़ने पर, ये आइटम भी बड़े हो जाएं.

इस इफ़ेक्ट के लिए Flexbox का इस्तेमाल करने पर, स्क्रीन के साइज़ में बदलाव होने पर, इन एलिमेंट की जगह में बदलाव करने के लिए आपको मीडिया क्वेरी की ज़रूरत नहीं पड़ेगी.

flex शॉर्टहैंड का मतलब है: flex: <flex-grow> <flex-shrink> <flex-basis>.

इस वजह से, अगर आपको अपने बॉक्स को <flex-basis> साइज़ में भरना है, छोटे साइज़ पर छोटा करना है, लेकिन किसी भी अतिरिक्त जगह को भरने के लिए बड़ा नहीं करना है, तो लिखें: flex: 0 1 <flex-basis>. इस मामले में, आपका <flex-basis> 150px है, इसलिए यह इस तरह दिखता है:

.parent {
  display: flex;
}

.child {
  flex: 0 1 150px;
}

अगर आपको चाहिए कि बॉक्स अगली लाइन पर रैप होने के दौरान, स्ट्रेच हो जाएं और स्पेस को भर दें, तो <flex-grow> को 1 पर सेट करें. ऐसा करने पर, यह इस तरह दिखेगा:

.parent {
  display: flex;
}

.child {
  flex: 1 1 150px;
}

अब, स्क्रीन का साइज़ बढ़ाने या घटाने पर, ये फ़्लेक्स आइटम छोटे और बड़े हो जाते हैं.

03. साइडबार में लिखा है: grid-template-columns: minmax(<min>, <max>) …)

इस डेमो में, ग्रिड लेआउट के लिए minmax फ़ंक्शन का फ़ायदा लिया गया है. यहां हम साइडबार का कम से कम साइज़ 150px पर सेट कर रहे हैं. हालांकि, बड़ी स्क्रीन पर इसे 25% तक बढ़ाया जा सकता है. साइडबार, अपने पैरंट के हॉरिज़ॉन्टल स्पेस का 25% हिस्सा तब तक लेगा, जब तक कि 25% 150px से छोटा न हो जाए.

इसे grid-template-columns की वैल्यू के तौर पर जोड़ें. इसके लिए, यह वैल्यू डालें: minmax(150px, 25%) 1fr. पहले कॉलम (इस मामले में साइडबार) के आइटम को 25% पर 150px का minmax मिलता है. वहीं, दूसरा आइटम (यहां main सेक्शन) बाकी जगह को एक 1fr ट्रैक के तौर पर लेता है.

.parent {
  display: grid;
  grid-template-columns: minmax(150px, 25%) 1fr;
}

04. पैनकेक स्टैक: grid-template-rows: auto 1fr auto

डिकॉन्स्ट्रक्टेड पैनकेक के विपरीत, इस उदाहरण में स्क्रीन का साइज़ बदलने पर, चाइल्ड एलिमेंट रैप नहीं होते. इसे आम तौर पर स्टिकी फ़ुटर कहा जाता है. इस लेआउट का इस्तेमाल, अक्सर वेबसाइटों और ऐप्लिकेशन, दोनों के लिए किया जाता है. मोबाइल ऐप्लिकेशन में, फ़ुटर आम तौर पर टूलबार होता है. वहीं, वेबसाइटों में सिंगल पेज ऐप्लिकेशन अक्सर इस ग्लोबल लेआउट का इस्तेमाल करते हैं.

कॉम्पोनेंट में display: grid जोड़ने पर, आपको एक कॉलम वाला ग्रिड मिलेगा. हालांकि, मुख्य एरिया उतना ही ऊंचा होगा जितना उसके नीचे मौजूद फ़ुटर के साथ कॉन्टेंट है.

फ़ुटर को सबसे नीचे रखने के लिए, ये जोड़ें:

.parent {
  display: grid;
  grid-template-rows: auto 1fr auto;
}

इससे हेडर और फ़ुटर कॉन्टेंट अपने-आप अपने चाइल्ड के साइज़ पर सेट हो जाता है. साथ ही, बाकी जगह (1fr) को मुख्य हिस्से में लागू कर देता है. वहीं, auto साइज़ वाली लाइन अपने चाइल्ड के कम से कम कॉन्टेंट के साइज़ पर सेट हो जाएगी. इससे कॉन्टेंट के साइज़ में बढ़ोतरी होने पर, लाइन अपने-आप बढ़ जाएगी.

05. क्लासिक होली ग्रेल लेआउट: grid-template: auto 1fr auto / auto 1fr auto

इस क्लासिक लेआउट में हेडर, फ़ुटर, बायां साइडबार, दायां साइडबार, और मुख्य कॉन्टेंट होता है. यह पिछले लेआउट जैसा ही है, लेकिन अब इसमें साइडबार भी हैं!

कोड की एक लाइन का इस्तेमाल करके, यह पूरा ग्रिड लिखने के लिए, grid-template प्रॉपर्टी का इस्तेमाल करें. इससे, पंक्तियों और कॉलम, दोनों को एक साथ सेट किया जा सकता है.

प्रॉपर्टी और वैल्यू का जोड़ा: grid-template: auto 1fr auto / auto 1fr auto. स्पेस से अलग की गई पहली और दूसरी सूचियों के बीच मौजूद स्लैश, पंक्तियों और कॉलम के बीच का ब्रेक है.

.parent {
  display: grid;
  grid-template: auto 1fr auto / auto 1fr auto;
}

पिछले उदाहरण की तरह, यहां भी हेडर और फ़ुटर में कॉन्टेंट का साइज़ अपने-आप सेट हो गया है. साथ ही, बाईं और दाईं ओर मौजूद साइडबार का साइज़, उनके चाइल्ड एलिमेंट के साइज़ के हिसाब से अपने-आप सेट हो गया है. हालांकि, इस बार यह वर्टिकल (ऊंचाई) के बजाय हॉरिज़ॉन्टल साइज़ (चौड़ाई) है.

06. 12-स्पैन ग्रिड: grid-template-columns: repeat(12, 1fr)

अगला ग्रिड भी क्लासिक है: 12-स्पैन वाला ग्रिड. repeat() फ़ंक्शन की मदद से, सीएसएस में ग्रिड तुरंत लिखे जा सकते हैं. ग्रिड टेंप्लेट कॉलम के लिए repeat(12, 1fr); का इस्तेमाल करने पर, आपको 1fr के 12 कॉलम मिलेंगे.

.parent {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
}

.child-span-12 {
  grid-column: 1 / 13;
}

अब आपके पास 12 कॉलम वाला ट्रैक ग्रिड है. हम अपने बच्चों को इस ग्रिड पर डाल सकते हैं. ऐसा करने का एक तरीका यह है कि ग्रिड लाइन का इस्तेमाल करके उन्हें प्लेस करें. उदाहरण के लिए, grid-column: 1 / 13 पहली लाइन से लेकर आखिरी (13वीं) लाइन तक और 12 कॉलम तक स्पैन करेगा. grid-column: 1 / 5;, पहले चार में शामिल होगा.

इसे लिखने का एक और तरीका है, span कीवर्ड का इस्तेमाल करना. span का इस्तेमाल करके, शुरुआती लाइन सेट की जाती है. इसके बाद, यह तय किया जाता है कि उस शुरुआती बिंदु से कितने कॉलम तक स्पैन करना है. इस मामले में, grid-column: 1 / span 12, grid-column: 1 / 13 के बराबर होगा और grid-column: 2 / span 6, grid-column: 2 / 8 के बराबर होगा.

.child-span-12 {
  grid-column: 1 / span 12;
}

07. रैम (दोहराएं, ऑटो, कम से कम और ज़्यादा से ज़्यादा): grid-template-columns(auto-fit, minmax(<base>, 1fr))

सातवें उदाहरण के लिए, पहले से सीखे गए कुछ कॉन्सेप्ट को जोड़कर, अपने-आप जगह ले लेने वाले और फ़्लेक्सिबल चाइल्ड लेआउट वाला रिस्पॉन्सिव लेआउट बनाएं. काफ़ी अच्छा. यहां याद रखने के लिए मुख्य शब्द repeat, auto-(fit|fill), और minmax()' हैं. इन्हें याद रखने के लिए, RAM का इस्तेमाल करें.

कुल मिलाकर, यह इस तरह दिखता है:

.parent {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

आपने फिर से repeat का इस्तेमाल किया है, लेकिन इस बार साफ़ तौर पर दी गई संख्या वाली वैल्यू के बजाय, auto-fit कीवर्ड का इस्तेमाल किया है. इससे, इन चाइल्ड एलिमेंट को अपने-आप प्लेस किया जा सकता है. इन चाइल्ड एलिमेंट की कम से कम वैल्यू 150px और ज़्यादा से ज़्यादा वैल्यू 1fr होती है. इसका मतलब है कि छोटी स्क्रीन पर, ये एलिमेंट पूरी 1fr चौड़ाई ले लेंगे. साथ ही, जब ये हर एलिमेंट 150px चौड़ाई तक पहुंच जाएंगे, तो ये एक ही लाइन पर फ़्लो होने लगेंगे.

auto-fit का इस्तेमाल करने पर, बॉक्स स्ट्रेच हो जाएंगे, क्योंकि उनका हॉरिज़ॉन्टल साइज़ 150 पिक्सल से ज़्यादा हो जाएगा. इससे बाकी बचे पूरे स्पेस को भरने में मदद मिलेगी. हालांकि, अगर इसे auto-fill में बदला जाता है, तो minmax फ़ंक्शन में उनके बेस साइज़ से ज़्यादा होने पर, वे स्ट्रेच नहीं होंगे:

.parent {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}

08. लाइन अप: justify-content: space-between

अगले लेआउट के लिए, यहां justify-content: space-between को दिखाना मुख्य बात है. यह पहले और आखिरी चाइल्ड एलिमेंट को उनके बाउंडिंग बॉक्स के किनारों पर रखता है. साथ ही, बाकी स्पेस को एलिमेंट के बीच बराबर-बराबर बांटता है. इन कार्ड को फ़्लेक्सबॉक्स डिसप्ले मोड में रखा गया है. साथ ही, flex-direction: column का इस्तेमाल करके, इनका डायरेक्शन कॉलम पर सेट किया गया है.

इससे, शीर्षक, ब्यौरा, और इमेज ब्लॉक, पैरंट कार्ड में वर्टिकल कॉलम में दिखते हैं. इसके बाद, justify-content: space-between का इस्तेमाल करने पर, पहले (टाइटल) और आखिरी (इमेज ब्लॉक) एलिमेंट, फ़्लेक्सबॉक्स के किनारों पर एंकर हो जाते हैं. साथ ही, इनके बीच मौजूद जानकारी देने वाला टेक्स्ट, हर एंडपॉइंट के बीच बराबर स्पेसिंग के साथ दिखता है.

.parent {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

09. Clamping My Style: clamp(<min>, <actual>, <max>)

यहां हम कम ब्राउज़र सपोर्ट वाली कुछ तकनीकों के बारे में बताएंगे. हालांकि, इनका लेआउट और रिस्पॉन्सिव यूज़र इंटरफ़ेस (यूआई) डिज़ाइन पर काफ़ी असर पड़ता है. इस डेमो में, क्लैंप का इस्तेमाल करके चौड़ाई को इस तरह सेट किया जा रहा है: width: clamp(<min>, <actual>, <max>).

इससे, साइज़ का कम से कम और ज़्यादा से ज़्यादा साइज़ और असल साइज़ सेट होता है. वैल्यू के साथ, यह इस तरह दिख सकता है:

.parent {
  width: clamp(23ch, 60%, 46ch);
}

इसका कम से कम साइज़ 23ch या 23 वर्ण यूनिट और ज़्यादा से ज़्यादा साइज़ 46ch या 46 वर्ण यूनिट होना चाहिए. वर्ण की चौड़ाई की इकाइयां, एलिमेंट के फ़ॉन्ट साइज़ (खास तौर पर 0 ग्लिफ़ की चौड़ाई) पर आधारित होती हैं. 'असल' साइज़ 50% है, जो इस एलिमेंट की पैरंट चौड़ाई का 50% है.

clamp() फ़ंक्शन यहां इस एलिमेंट को 50% चौड़ाई बनाए रखने की सुविधा दे रहा है. यह सुविधा तब तक बनी रहेगी, जब तक 50%, 46ch (बड़े व्यूपोर्ट पर) से ज़्यादा या 23ch (छोटे व्यूपोर्ट पर) से कम न हो जाए. आप देख सकते हैं कि पैरंट साइज़ को स्ट्रेच और छोटा करने पर, इस कार्ड की चौड़ाई क्लैंप किए गए सबसे बड़े पॉइंट तक बढ़ जाती है और क्लैंप किए गए सबसे छोटे पॉइंट तक कम हो जाती है. इसके बाद, यह पैरंट में बीच में दिखता है, क्योंकि हमने इसे बीच में दिखाने के लिए अतिरिक्त प्रॉपर्टी लागू की हैं. इससे, टेक्स्ट को आसानी से पढ़ा जा सकता है, क्योंकि टेक्स्ट बहुत चौड़ा (46ch से ज़्यादा) या बहुत छोटा (23ch से कम) नहीं होगा.

रिस्पॉन्सिव टाइपोग्राफ़ी लागू करने का यह भी एक बेहतरीन तरीका है. उदाहरण के लिए, कुछ ऐसा लिखें: font-size: clamp(1.5rem, 20vw, 3rem). इस मामले में, हेडलाइन का फ़ॉन्ट-साइज़ हमेशा 1.5rem और 3rem के बीच ही रहेगा. हालांकि, यह 20vw की असल वैल्यू के आधार पर बड़ा और छोटा हो सकता है, ताकि यह व्यूपोर्ट की चौड़ाई में फ़िट हो सके.

यह एक बेहतरीन तकनीक है, जिससे यह पक्का किया जा सकता है कि टेक्स्ट को कम से कम और ज़्यादा से ज़्यादा साइज़ में पढ़ा जा सके. हालांकि, ध्यान रखें कि यह सभी आधुनिक ब्राउज़र पर काम नहीं करती. इसलिए, पक्का करें कि आपके पास फ़ॉलबैक हों और आपने टेस्ट किया हो.

10. आसपेक्ट रेशियो का ध्यान रखना: aspect-ratio: <width> / <height>

आखिर में, यह आखिरी लेआउट टूल, सबसे ज़्यादा एक्सपेरिमेंटल है. इसे हाल ही में Chromium 84 में Chrome Canary के लिए लॉन्च किया गया था. Firefox भी इसे लागू करने की कोशिश कर रहा है, लेकिन फ़िलहाल यह किसी भी ब्राउज़र के स्टेबल वर्शन में उपलब्ध नहीं है.

हालांकि, हम इस बारे में बताना चाहते हैं, क्योंकि यह अक्सर होने वाली समस्या है. ऐसा करने पर, इमेज का आसपेक्ट रेशियो (लंबाई-चौड़ाई का अनुपात) पहले जैसा ही रहता है.

aspect-ratio प्रॉपर्टी की मदद से, कार्ड का साइज़ बदलने पर भी हरा विज़ुअल ब्लॉक, 16 x 9 आसपेक्ट रेशियो में दिखता है. हम aspect-ratio: 16 / 9 के साथ आसपेक्ट रेशियो का पालन कर रहे हैं.

.video {
  aspect-ratio: 16 / 9;
}

इस प्रॉपर्टी के बिना 16 x 9 आसपेक्ट रेशियो बनाए रखने के लिए, आपको padding-top हैक का इस्तेमाल करना होगा. साथ ही, ऊपर से नीचे तक का आसपेक्ट रेशियो सेट करने के लिए, उसे 56.25% पैडिंग देनी होगी. हम जल्द ही इसकी एक प्रॉपर्टी लॉन्च करेंगे, ताकि हैकिंग से बचा जा सके और प्रतिशत का हिसाब लगाने की ज़रूरत न पड़े. 1 / 1 रेशियो वाला स्क्वेयर, 2 / 1 रेशियो वाला 2:1, और अपनी ज़रूरत के हिसाब से कोई भी आसपेक्ट रेशियो सेट किया जा सकता है.

.square {
  aspect-ratio: 1 / 1;
}

यह सुविधा अभी पूरी तरह से उपलब्ध नहीं है, लेकिन इस बारे में जानना अच्छा है. इससे डेवलपर को कई समस्याओं से निजात मिलती है. मुझे भी कई बार इन समस्याओं का सामना करना पड़ा है. खास तौर पर, वीडियो और iframes से जुड़ी समस्याओं का.

नतीजा

सीएसएस की 10 शानदार लाइनों के बारे में जानने के लिए धन्यवाद. ज़्यादा जानने के लिए, पूरा वीडियो देखें और खुद डेमो आज़माएं.