CSS ग्रिड
उदाहरणहरू र कोड स्निपेटहरू सहित CSS ग्रिडमा निर्मित हाम्रो वैकल्पिक लेआउट प्रणाली कसरी सक्षम गर्ने, प्रयोग गर्ने र अनुकूलन गर्ने सिक्नुहोस्।
बुटस्ट्र्यापको पूर्वनिर्धारित ग्रिड प्रणालीले लाखौं मानिसहरूले प्रयास गरेको र परीक्षण गरेको CSS लेआउट प्रविधिहरूको एक दशकभन्दा बढीको परिणतिलाई प्रतिनिधित्व गर्दछ। तर, यो हामीले नयाँ CSS ग्रिड जस्ता ब्राउजरहरूमा देखिरहेका धेरै आधुनिक CSS सुविधाहरू र प्रविधिहरू बिना पनि सिर्जना गरिएको थियो।
यसले कसरी काम गर्छ
Bootstrap 5 को साथ, हामीले CSS ग्रिडमा निर्मित छुट्टै ग्रिड प्रणाली सक्षम गर्ने विकल्प थपेका छौं, तर बुटस्ट्र्याप ट्विस्टसँग। तपाइँ अझै पनि कक्षाहरू प्राप्त गर्नुहुन्छ जुन तपाइँ उत्तरदायी लेआउटहरू निर्माण गर्नको लागि आवेदन गर्न सक्नुहुन्छ, तर हुड अन्तर्गत फरक दृष्टिकोणको साथ।
-
CSS ग्रिड अप्ट-इन छ। सेटिङ गरेर पूर्वनिर्धारित ग्रिड प्रणाली असक्षम गर्नुहोस्
$enable-grid-classes: false
र सेटिङद्वारा CSS ग्रिड सक्षम गर्नुहोस्$enable-cssgrid: true
। त्यसपछि, आफ्नो Sass पुन: कम्पाइल गर्नुहोस्। -
को उदाहरणहरू प्रतिस्थापन
.row
गर्नुहोस्.grid
।.grid
कक्षाले तपाइँको HTML मार्फत निर्माण गर्ने एउटा सेटdisplay: grid
र सिर्जना गर्दछ ।grid-template
-
.col-*
कक्षाहरू कक्षाहरूसँग बदल्नुहोस्.g-col-*
। यो किनभने हाम्रो CSS ग्रिड स्तम्भहरूलेgrid-column
गुणको सट्टा प्रयोग गर्दछwidth
। -
स्तम्भहरू र गटर आकारहरू CSS चरहरू मार्फत सेट गरिएका छन्। यसलाई अभिभावकमा सेट गर्नुहोस्
.grid
र आफूले चाहे अनुसार अनुकूलन गर्नुहोस्, इनलाइन वा स्टाइलसिटमा,--bs-columns
र सँग--bs-gap
।
भविष्यमा, बुटस्ट्र्याप सम्भवतः हाइब्रिड समाधानमा परिवर्तन हुनेछ किनकि gap
सम्पत्तीले फ्लेक्सबक्सको लागि लगभग पूर्ण ब्राउजर समर्थन प्राप्त गरेको छ।
मुख्य भिन्नताहरू
पूर्वनिर्धारित ग्रिड प्रणालीको तुलनामा:
-
फ्लेक्स उपयोगिताहरूले CSS ग्रिड स्तम्भहरूलाई समान रूपमा असर गर्दैन।
-
ग्याप्सले गटरहरू प्रतिस्थापन गर्दछ।
gap
सम्पत्तीले हाम्रो पूर्वनिर्धारित ग्रिड प्रणालीबाट तेर्सोलाई प्रतिस्थापन गर्दछ रpadding
जस्तै कार्य गर्दछmargin
। -
जस्तै, s को विपरीत
.row
,.grid
s मा कुनै नकारात्मक मार्जिन छैन र मार्जिन उपयोगिताहरू ग्रिड गटरहरू परिवर्तन गर्न प्रयोग गर्न सकिँदैन। पूर्वनिर्धारित रूपमा ग्रिड अन्तरहरू तेर्सो र ठाडो रूपमा लागू गरिन्छ। थप विवरणहरूको लागि अनुकूलन खण्ड हेर्नुहोस् । -
style="--bs-columns: 3;"
इनलाइन र अनुकूलन शैलीहरू परिमार्जक वर्गहरू (जस्तै, बनामclass="row-cols-3"
) को लागि प्रतिस्थापनको रूपमा हेर्नु पर्छ । -
नेस्टिङले समान रूपमा काम गर्दछ, तर तपाईंले नेस्टेडको प्रत्येक उदाहरणमा आफ्नो स्तम्भ गणनाहरू रिसेट गर्न आवश्यक हुन सक्छ
.grid
। विवरणका लागि नेस्टिङ खण्ड हेर्नुहोस्।
उदाहरणहरू
तीन स्तम्भहरू
.g-col-4
सबै भ्यूपोर्टहरू र उपकरणहरूमा तीन समान-चौडाइ स्तम्भहरू कक्षाहरू प्रयोग गरेर सिर्जना गर्न सकिन्छ । भ्यूपोर्ट साइज अनुसार लेआउट परिवर्तन गर्न उत्तरदायी कक्षाहरू थप्नुहोस् ।
<div class="grid text-center">
<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 text-center">
<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 text-center">
<div class="g-col-6">.g-col-6</div>
<div class="g-col-6">.g-col-6</div>
</div>
बेर्नु
ग्रिड वस्तुहरू स्वचालित रूपमा अर्को लाइनमा र्याप हुन्छन् जब त्यहाँ तेर्सो रूपमा कुनै ठाउँ छैन। नोट गर्नुहोस् कि gap
ग्रिड वस्तुहरू बीच तेर्सो र ठाडो अन्तरहरूमा लागू हुन्छ।
<div class="grid text-center">
<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 text-center">
<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>
स्वतः स्तम्भहरू
जब ग्रिड वस्तुहरूमा कुनै कक्षाहरू छैनन् (a को तत्काल बच्चाहरू .grid
), प्रत्येक ग्रिड वस्तु स्वचालित रूपमा एक स्तम्भमा आकार हुनेछ।
<div class="grid text-center">
<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 text-center">
<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>
नेस्टिङ
.grid
हाम्रो पूर्वनिर्धारित ग्रिड प्रणाली जस्तै, हाम्रो CSS ग्रिडले s को सजिलो नेस्टिङको लागि अनुमति दिन्छ । यद्यपि, पूर्वनिर्धारित विपरीत, यो ग्रिडले पङ्क्तिहरू, स्तम्भहरू र खाली ठाउँहरूमा परिवर्तनहरू इनहेरिट गर्छ। तलको उदाहरणलाई विचार गर्नुहोस्:
- हामी स्थानीय CSS चरको साथ स्तम्भहरूको पूर्वनिर्धारित संख्या ओभरराइड गर्छौं
--bs-columns: 3
:। - पहिलो स्वत: स्तम्भमा, स्तम्भ गणना इनहेरिट गरिएको छ र प्रत्येक स्तम्भ उपलब्ध चौडाइको एक तिहाइ हो।
- दोस्रो स्वत: स्तम्भमा, हामीले नेस्टेडमा रहेको स्तम्भ गणनालाई
.grid
१२ (हाम्रो पूर्वनिर्धारित) मा रिसेट गरेका छौं। - तेस्रो स्वत: स्तम्भमा कुनै नेस्टेड सामग्री छैन।
अभ्यासमा यसले हाम्रो पूर्वनिर्धारित ग्रिड प्रणालीको तुलनामा थप जटिल र अनुकूलन लेआउटहरूको लागि अनुमति दिन्छ।
<div class="grid text-center" 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)
हाम्रो CSS ग्रिड पङ्क्तिहरूका लागि प्रयोग गर्छौं, जसले बेवास्ता गर्छ --bs-rows
किनभने त्यो अझै कतै सेट गरिएको छैन। एक पटक यो भएपछि, .grid
उदाहरणले फलब्याक मानको सट्टा त्यो मान प्रयोग गर्नेछ 1
।
कुनै ग्रिड कक्षाहरू छैनन्
तात्कालिक बालबालिका तत्वहरू ग्रिड वस्तुहरू हुन्, त्यसैले तिनीहरू स्पष्ट रूपमा कक्षा .grid
थप नगरिकन आकार दिइनेछन् ।.g-col
<div class="grid text-center" style="--bs-columns: 3;">
<div>Auto-column</div>
<div>Auto-column</div>
<div>Auto-column</div>
</div>
स्तम्भहरू र खाली ठाउँहरू
स्तम्भहरूको संख्या र खाली ठाउँ समायोजन गर्नुहोस्।
<div class="grid text-center" 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 text-center" 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 text-center" 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 text-center" 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 text-center" 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
। यसले प्रभावकारी रूपमा हाम्रो कम्पाइल गरिएको CSS मा उत्पन्न गरिएका कक्षाहरूको सङ्ख्या पूर्वनिर्धारित गर्छ। तपाईंसँग यहाँ दुई विकल्पहरू छन्:
- ती पूर्वनिर्धारित Sass चरहरू परिमार्जन गर्नुहोस् र तपाईंको CSS पुन: कम्पाइल गर्नुहोस्।
- प्रदान गरिएका कक्षाहरू बढाउन इनलाइन वा अनुकूलन शैलीहरू प्रयोग गर्नुहोस्।
उदाहरणका लागि, तपाईंले स्तम्भ गणना बढाउन र ग्याप साइज परिवर्तन गर्न सक्नुहुन्छ, र त्यसपछि इनलाइन शैलीहरू र पूर्वनिर्धारित CSS ग्रिड स्तम्भ वर्गहरू (जस्तै, .g-col-4
) को मिश्रणको साथ आफ्नो "स्तम्भहरू" लाई आकार दिन सक्नुहुन्छ।
<div class="grid text-center" 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>