CSS గ్రిడ్
ఉదాహరణలు మరియు కోడ్ స్నిప్పెట్లతో CSS గ్రిడ్లో నిర్మించిన మా ప్రత్యామ్నాయ లేఅవుట్ సిస్టమ్ను ఎలా ప్రారంభించాలో, ఉపయోగించాలో మరియు అనుకూలీకరించాలో తెలుసుకోండి.
బూట్స్ట్రాప్ యొక్క డిఫాల్ట్ గ్రిడ్ సిస్టమ్ దశాబ్దానికి పైగా CSS లేఅవుట్ టెక్నిక్ల ముగింపును సూచిస్తుంది, దీనిని మిలియన్ల మంది వ్యక్తులు ప్రయత్నించారు మరియు పరీక్షించారు. కానీ, కొత్త CSS గ్రిడ్ వంటి బ్రౌజర్లలో మనం చూస్తున్న అనేక ఆధునిక CSS లక్షణాలు మరియు సాంకేతికతలు లేకుండా కూడా ఇది సృష్టించబడింది.
అది ఎలా పని చేస్తుంది
బూట్స్ట్రాప్ 5తో, మేము CSS గ్రిడ్లో నిర్మించబడిన ప్రత్యేక గ్రిడ్ సిస్టమ్ను ప్రారంభించే ఎంపికను జోడించాము, కానీ బూట్స్ట్రాప్ ట్విస్ట్తో. మీరు ఇప్పటికీ ప్రతిస్పందించే లేఅవుట్లను రూపొందించడానికి ఇష్టానుసారం దరఖాస్తు చేసుకోగల తరగతులను పొందుతారు, కానీ హుడ్ కింద వేరే విధానంతో.
-
CSS గ్రిడ్ ప్రారంభించబడింది. సెట్ చేయడం ద్వారా డిఫాల్ట్ గ్రిడ్ సిస్టమ్ను నిలిపివేయండి మరియు సెట్ చేయడం
$enable-grid-classes: false
ద్వారా CSS గ్రిడ్ను ప్రారంభించండి$enable-cssgrid: true
. అప్పుడు, మీ సాస్ని మళ్లీ కంపైల్ చేయండి. -
.row
యొక్క ఉదాహరణలను తో భర్తీ చేయండి.grid
. తరగతి.grid
సెట్ చేస్తుంది మరియు మీరు మీ HTMLతో రూపొందించినdisplay: grid
దాన్ని సృష్టిస్తుంది .grid-template
-
.col-*
తరగతులను తరగతులతో భర్తీ చేయండి.g-col-*
. ఎందుకంటే మా CSS గ్రిడ్ నిలువు వరుసలుgrid-column
బదులుగా ప్రాపర్టీని ఉపయోగిస్తాయిwidth
. -
నిలువు వరుసలు మరియు గట్టర్ పరిమాణాలు CSS వేరియబుల్స్ ద్వారా సెట్ చేయబడ్డాయి. వీటిని పేరెంట్పై సెట్ చేయండి
.grid
మరియు మీకు కావలసిన విధంగా అనుకూలీకరించండి, ఇన్లైన్ లేదా స్టైల్షీట్లో,--bs-columns
మరియు--bs-gap
.
భవిష్యత్తులో, బూట్స్ట్రాప్ gap
ఫ్లెక్స్బాక్స్కు దాదాపు పూర్తి బ్రౌజర్ మద్దతును పొందింది కాబట్టి బూట్స్ట్రాప్ హైబ్రిడ్ పరిష్కారానికి మారవచ్చు.
కీ తేడాలు
డిఫాల్ట్ గ్రిడ్ సిస్టమ్తో పోలిస్తే:
-
Flex వినియోగాలు CSS గ్రిడ్ నిలువు వరుసలను అదే విధంగా ప్రభావితం చేయవు.
-
ఖాళీలు గట్టర్లను భర్తీ చేస్తాయి.
gap
ప్రాపర్టీpadding
మా డిఫాల్ట్ గ్రిడ్ సిస్టమ్ నుండి క్షితిజ సమాంతరాన్ని భర్తీ చేస్తుంది మరియు మరిన్ని వాటిలా పనిచేస్తుందిmargin
. -
అలాగే, s వలె కాకుండా
.row
,.grid
sకి ప్రతికూల మార్జిన్లు లేవు మరియు గ్రిడ్ గట్టర్లను మార్చడానికి మార్జిన్ యుటిలిటీలు ఉపయోగించబడవు. గ్రిడ్ ఖాళీలు డిఫాల్ట్గా అడ్డంగా మరియు నిలువుగా వర్తించబడతాయి. మరిన్ని వివరాల కోసం అనుకూలీకరణ విభాగాన్ని చూడండి . -
ఇన్లైన్ మరియు కస్టమ్ స్టైల్లను మాడిఫైయర్ క్లాస్లకు ప్రత్యామ్నాయాలుగా చూడాలి (ఉదా,
style="--bs-columns: 3;"
vsclass="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>
గూడు కట్టడం
మా డిఫాల్ట్ గ్రిడ్ సిస్టమ్ మాదిరిగానే, మా CSS గ్రిడ్ .grid
లు సులభంగా గూడు కట్టుకోవడానికి అనుమతిస్తుంది. అయినప్పటికీ, డిఫాల్ట్ వలె కాకుండా, ఈ గ్రిడ్ అడ్డు వరుసలు, నిలువు వరుసలు మరియు ఖాళీలలో మార్పులను వారసత్వంగా పొందుతుంది. దిగువ ఉదాహరణను పరిగణించండి:
- మేము స్థానిక CSS వేరియబుల్తో డిఫాల్ట్ నిలువు వరుసల సంఖ్యను భర్తీ చేస్తాము:
--bs-columns: 3
. - మొదటి స్వీయ-నిలువు వరుసలో, నిలువు వరుస గణన వారసత్వంగా ఉంటుంది మరియు ప్రతి నిలువు వరుస అందుబాటులో ఉన్న వెడల్పులో మూడింట ఒక వంతు ఉంటుంది.
- రెండవ స్వీయ-నిలువు వరుసలో, మేము నెస్టెడ్లోని కాలమ్ కౌంట్ను
.grid
12కి రీసెట్ చేసాము (మా డిఫాల్ట్). - మూడవ స్వీయ-నిలువు వరుసలో సమూహ కంటెంట్ లేదు.
ఆచరణలో ఇది మా డిఫాల్ట్ గ్రిడ్ సిస్టమ్తో పోల్చినప్పుడు మరింత సంక్లిష్టమైన మరియు అనుకూల లేఅవుట్లను అనుమతిస్తుంది.
<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 వేరియబుల్స్కు డిఫాల్ట్ విలువ లేదు; బదులుగా, వారు స్థానిక ఉదాహరణ అందించబడే వరకు ఉపయోగించే ఫాల్బ్యాక్ విలువలను వర్తింపజేస్తారు . ఉదాహరణకు, మేము మా CSS గ్రిడ్ అడ్డు వరుసల కోసం ఉపయోగిస్తాము , ఇది ఇంకా ఎక్కడా సెట్ చేయబడనందున var(--bs-rows, 1)
విస్మరిస్తుంది . --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
. gap
మేము s లో ఉపయోగిస్తామని గమనించండి .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
లను కలిగి ఉండవచ్చు, ఇది ఒకే విలువను (అన్ని వైపులా) లేదా ఒక జత విలువలను (నిలువు మరియు క్షితిజ సమాంతర) తీసుకోవచ్చు. ఇది కోసం ఇన్లైన్ శైలితో 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>