सीएसएस ग्रिड
उदाहरण और कोड स्निपेट के साथ CSS ग्रिड पर निर्मित हमारे वैकल्पिक लेआउट सिस्टम को सक्षम, उपयोग और अनुकूलित करना सीखें।
बूटस्ट्रैप का डिफ़ॉल्ट ग्रिड सिस्टम एक दशक से अधिक की सीएसएस लेआउट तकनीकों की परिणति का प्रतिनिधित्व करता है, जिसे लाखों लोगों द्वारा आजमाया और परखा गया है। लेकिन, यह कई आधुनिक सीएसएस सुविधाओं और तकनीकों के बिना भी बनाया गया था जिन्हें हम नए सीएसएस ग्रिड जैसे ब्राउज़र में देख रहे हैं।
यह काम किस प्रकार करता है
बूटस्ट्रैप 5 के साथ, हमने एक अलग ग्रिड सिस्टम को सक्षम करने का विकल्प जोड़ा है जो सीएसएस ग्रिड पर बनाया गया है, लेकिन बूटस्ट्रैप ट्विस्ट के साथ। आपको अभी भी कक्षाएं मिलती हैं जिन्हें आप उत्तरदायी लेआउट बनाने के लिए लागू कर सकते हैं, लेकिन हुड के तहत एक अलग दृष्टिकोण के साथ।
-
CSS ग्रिड ऑप्ट-इन है।
$enable-grid-classes: false
सीएसएस ग्रिड को सेट करके और सेटिंग करके डिफ़ॉल्ट ग्रिड सिस्टम को अक्षम करें$enable-cssgrid: true
। फिर, अपने Sass को पुन: संकलित करें। -
के उदाहरणों को से
.row
बदलें.grid
।.grid
वर्ग सेट करताdisplay: grid
है और बनाता हैgrid-template
जिसे आप अपने एचटीएमएल के साथ बनाते हैं । -
.col-*
कक्षाओं को कक्षाओं से बदलें.g-col-*
। ऐसा इसलिए है क्योंकि हमारे सीएसएस ग्रिड कॉलम केgrid-column
बजाय संपत्ति का उपयोग करते हैंwidth
। -
कॉलम और गटर का आकार CSS चरों के माध्यम से निर्धारित किया जाता है। इन्हें पैरेंट पर सेट करें
.grid
और अपनी इच्छानुसार इनलाइन या स्टाइलशीट में--bs-columns
और के साथ कस्टमाइज़ करें--bs-gap
।
भविष्य में, बूटस्ट्रैप संभवतः एक हाइब्रिड समाधान में स्थानांतरित हो जाएगा क्योंकि gap
संपत्ति ने फ्लेक्सबॉक्स के लिए लगभग पूर्ण ब्राउज़र समर्थन प्राप्त कर लिया है।
मुख्य अंतर
डिफ़ॉल्ट ग्रिड सिस्टम की तुलना में:
-
फ्लेक्स उपयोगिताओं सीएसएस ग्रिड कॉलम को उसी तरह प्रभावित नहीं करती हैं।
-
अंतराल गटर की जगह लेता है। प्रॉपर्टी हमारे डिफ़ॉल्ट ग्रिड सिस्टम से
gap
हॉरिजॉन्टल को बदल देतीpadding
है औरmargin
. -
जैसे, s के विपरीत
.row
,.grid
s का कोई नकारात्मक मार्जिन नहीं है और मार्जिन उपयोगिताओं का उपयोग ग्रिड गटर को बदलने के लिए नहीं किया जा सकता है। ग्रिड अंतराल डिफ़ॉल्ट रूप से क्षैतिज और लंबवत रूप से लागू होते हैं। अधिक विवरण के लिए अनुकूलन अनुभाग देखें । -
style="--bs-columns: 3;"
इनलाइन और कस्टम शैलियों को संशोधक वर्गों (जैसे, बनामclass="row-cols-3"
) के प्रतिस्थापन के रूप में देखा जाना चाहिए । -
नेस्टिंग समान रूप से काम करता है, लेकिन आपको नेस्टेड के प्रत्येक इंस्टेंस पर अपने कॉलम की संख्या को रीसेट करने की आवश्यकता हो सकती है
.grid
। विवरण के लिए नेस्टिंग अनुभाग देखें ।
उदाहरण
तीन कॉलम
.g-col-4
कक्षाओं का उपयोग करके सभी व्यूपोर्ट और उपकरणों में तीन समान-चौड़ाई वाले कॉलम बनाए जा सकते हैं। व्यूपोर्ट आकार के आधार पर लेआउट बदलने के लिए उत्तरदायी वर्ग जोड़ें ।
<div class="grid">
<div class="g-col-4">.g-col-4</div>
<div class="g-col-4">.g-col-4</div>
<div class="g-col-4">.g-col-4</div>
</div>
उत्तरदायी
व्यूपोर्ट में अपना लेआउट समायोजित करने के लिए प्रतिक्रियाशील कक्षाओं का उपयोग करें। यहां हम सबसे छोटे व्यूपोर्ट पर दो कॉलम से शुरू करते हैं, और फिर मध्यम व्यूपोर्ट और उससे ऊपर के तीन कॉलम तक बढ़ते हैं।
<div class="grid">
<div class="g-col-6 g-col-md-4">.g-col-6 .g-col-md-4</div>
<div class="g-col-6 g-col-md-4">.g-col-6 .g-col-md-4</div>
<div class="g-col-6 g-col-md-4">.g-col-6 .g-col-md-4</div>
</div>
इसकी तुलना सभी व्यूपोर्ट पर इस दो कॉलम लेआउट से करें।
<div class="grid">
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
</div>
रैपिंग
क्षैतिज रूप से कोई और जगह न होने पर ग्रिड आइटम स्वचालित रूप से अगली पंक्ति में आ जाते हैं। ध्यान दें कि gap
ग्रिड वस्तुओं के बीच क्षैतिज और लंबवत अंतराल पर लागू होता है।
<div class="grid">
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
</div>
प्रारंभ होगा
प्रारंभ कक्षाएं हमारे डिफ़ॉल्ट ग्रिड की ऑफसेट कक्षाओं को प्रतिस्थापित करने का लक्ष्य रखती हैं, लेकिन वे पूरी तरह से समान नहीं हैं। CSS ग्रिड शैलियों के माध्यम से एक ग्रिड टेम्पलेट बनाता है जो ब्राउज़र को "इस कॉलम से शुरू करें" और "इस कॉलम पर समाप्त होता है" बताता है। वे गुण हैं grid-column-start
और grid-column-end
. प्रारंभ कक्षाएं पूर्व के लिए आशुलिपि हैं। अपने कॉलम को आकार और संरेखित करने के लिए उन्हें कॉलम क्लास के साथ जोड़ दें, हालांकि आपको इसकी आवश्यकता है। प्रारंभ कक्षाएं इन गुणों के लिए एक अमान्य मान के 1
रूप में प्रारंभ होती हैं।0
<div class="grid">
<div class="g-col-3 g-start-2">.g-col-3 .g-start-2</div>
<div class="g-col-4 g-start-6">.g-col-4 .g-start-6</div>
</div>
ऑटो कॉलम
जब ग्रिड आइटम पर कोई वर्ग नहीं होता है ( के तत्काल बच्चे .grid
), प्रत्येक ग्रिड आइटम स्वचालित रूप से एक कॉलम के आकार का हो जाएगा।
<div class="grid">
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
</div>
यह व्यवहार ग्रिड कॉलम कक्षाओं के साथ मिश्रित किया जा सकता है।
<div class="grid">
<div class="g-col-6">.g-col-6</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
<div>1</div>
</div>
घोंसला करने की क्रिया
हमारे डिफ़ॉल्ट ग्रिड सिस्टम के समान, हमारा CSS ग्रिड .grid
s के आसान नेस्टिंग की अनुमति देता है। हालाँकि, डिफ़ॉल्ट के विपरीत, यह ग्रिड पंक्तियों, स्तंभों और अंतरालों में परिवर्तन को इनहेरिट करता है। नीचे दिए गए उदाहरण पर विचार करें:
- हम स्थानीय सीएसएस चर के साथ कॉलम की डिफ़ॉल्ट संख्या को ओवरराइड करते हैं:
--bs-columns: 3
. - पहले ऑटो-कॉलम में, कॉलम की गिनती इनहेरिट की जाती है और प्रत्येक कॉलम उपलब्ध चौड़ाई का एक तिहाई होता है।
- दूसरे ऑटो-कॉलम में, हमने नेस्टेड पर कॉलम काउंट
.grid
को 12 (हमारा डिफ़ॉल्ट) पर रीसेट कर दिया है। - तीसरे ऑटो-कॉलम में कोई नेस्टेड सामग्री नहीं है।
व्यवहार में यह हमारे डिफ़ॉल्ट ग्रिड सिस्टम की तुलना में अधिक जटिल और कस्टम लेआउट की अनुमति देता है।
<div class="grid" style="--bs-columns: 3;">
<div>
First auto-column
<div class="grid">
<div>Auto-column</div>
<div>Auto-column</div>
</div>
</div>
<div>
Second auto-column
<div class="grid" style="--bs-columns: 12;">
<div class="g-col-6">6 of 12</div>
<div class="g-col-4">4 of 12</div>
<div class="g-col-2">2 of 12</div>
</div>
</div>
<div>Third auto-column</div>
</div>
अनुकूलित
स्तंभों की संख्या, पंक्तियों की संख्या और अंतराल की चौड़ाई को स्थानीय CSS चरों के साथ अनुकूलित करें।
चर | फ़ॉलबैक मान | विवरण |
---|---|---|
--bs-rows |
1 |
आपके ग्रिड टेम्पलेट में पंक्तियों की संख्या |
--bs-columns |
12 |
आपके ग्रिड टेम्पलेट में स्तंभों की संख्या |
--bs-gap |
1.5rem |
स्तंभों के बीच की खाई का आकार (ऊर्ध्वाधर और क्षैतिज) |
इन CSS चरों का कोई डिफ़ॉल्ट मान नहीं है; इसके बजाय, वे फ़ॉलबैक मान लागू करते हैं जिनका उपयोग स्थानीय उदाहरण प्रदान किए जाने तक किया जाता है। उदाहरण के लिए, हम var(--bs-rows, 1)
अपनी सीएसएस ग्रिड पंक्तियों के लिए उपयोग करते हैं, जो अनदेखा करता --bs-rows
है क्योंकि इसे अभी तक कहीं भी सेट नहीं किया गया है। एक बार ऐसा हो जाने पर, .grid
इंस्टेंस फॉलबैक मान के बजाय उस मान का उपयोग करेगा 1
।
कोई ग्रिड कक्षाएं नहीं
तत्काल बच्चों के तत्व ग्रिड आइटम हैं, इसलिए उन्हें स्पष्ट रूप से कक्षा .grid
जोड़ने के बिना आकार दिया जाएगा ।.g-col
<div class="grid" style="--bs-columns: 3;">
<div>Auto-column</div>
<div>Auto-column</div>
<div>Auto-column</div>
</div>
कॉलम और अंतराल
स्तंभों की संख्या और अंतराल को समायोजित करें।
<div class="grid" style="--bs-columns: 4; --bs-gap: 5rem;">
<div class="g-col-2">.g-col-2</div>
<div class="g-col-2">.g-col-2</div>
</div>
<div class="grid" style="--bs-columns: 10; --bs-gap: 1rem;">
<div class="g-col-6">.g-col-6</div>
<div class="g-col-4">.g-col-4</div>
</div>
पंक्तियाँ जोड़ना
अधिक पंक्तियाँ जोड़ना और स्तंभों का स्थान बदलना:
<div class="grid" style="--bs-rows: 3; --bs-columns: 3;">
<div>Auto-column</div>
<div class="g-start-2" style="grid-row: 2">Auto-column</div>
<div class="g-start-3" style="grid-row: 3">Auto-column</div>
</div>
अंतराल
केवल वर्टिकल गैप को संशोधित करके बदलें row-gap
। ध्यान दें कि हम s gap
पर उपयोग करते हैं .grid
, लेकिन row-gap
और column-gap
आवश्यकतानुसार संशोधित किया जा सकता है।
<div class="grid" style="row-gap: 0;">
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
</div>
उसके कारण, आपके पास अलग-अलग लंबवत और क्षैतिज gap
s हो सकते हैं, जो एक मान (सभी पक्षों) या मानों की एक जोड़ी (ऊर्ध्वाधर और क्षैतिज) ले सकते हैं। gap
इसे , या हमारे --bs-gap
CSS वेरिएबल के लिए इनलाइन शैली के साथ लागू किया जा सकता है ।
<div class="grid" style="--bs-gap: .25rem 1rem;">
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
</div>
सास
CSS ग्रिड की एक सीमा यह है कि हमारे डिफ़ॉल्ट वर्ग अभी भी दो Sass चर द्वारा उत्पन्न होते हैं, $grid-columns
और $grid-gutter-width
. यह प्रभावी रूप से हमारे संकलित सीएसएस में उत्पन्न कक्षाओं की संख्या को पूर्व निर्धारित करता है। यहां आपके पास दो विकल्प हैं:
- उन डिफ़ॉल्ट Sass चरों को संशोधित करें और अपने CSS को पुन: संकलित करें।
- प्रदान की गई कक्षाओं को बढ़ाने के लिए इनलाइन या कस्टम शैलियों का उपयोग करें।
उदाहरण के लिए, आप कॉलम की संख्या बढ़ा सकते हैं और गैप का आकार बदल सकते हैं, और फिर इन��ाइन शैलियों और पूर्वनिर्धारित CSS ग्रिड कॉलम वर्गों (जैसे, .g-col-4
) के मिश्रण के साथ अपने "कॉलम" को आकार दे सकते हैं।
<div class="grid" style="--bs-columns: 18; --bs-gap: .5rem;">
<div style="grid-column: span 14;">14 columns</div>
<div class="g-col-4">.g-col-4</div>
</div>