Vertikaliai centruokite tekstą Div viduje su CSS
Vertikaliai išlygiuoti tekstą „div“ gali būti įprastas iššūkis kuriant žiniatinklio dizainą. Užtikrinkite, kad tekstas būtų idealiai centre, gali pagerinti turinio estetiką ir skaitomumą.
Šiame straipsnyje išnagrinėsime įvairius būdus, kaip pasiekti vertikalų teksto centravimą „div“, naudojant CSS. Pradėsime nuo paprasto pavyzdžio, o tada įsigilinsime į pažangesnius metodus, siekdami užtikrinti suderinamumą įvairiose naršyklėse ir įrenginiuose.
komandą | apibūdinimas |
---|---|
display: flex; | Apibrėžia lanksčią talpyklą, leidžiančią naudoti „flexbox“ išdėstymą. |
justify-content: center; | Lankstūs daiktai lanksčiame konteineryje horizontaliai centruojami. |
align-items: center; | Vertikaliai centruoja lankstus elementus lankstaus konteinerio viduje. |
display: grid; | Apibrėžia tinklelio talpyklą, leidžiančią naudoti tinklelio išdėstymą. |
place-items: center; | Centruoja elementus tiek horizontaliai, tiek vertikaliai tinklelio konteineryje. |
display: table; | Apibrėžia elementą kaip lentelę, leidžiančią taikyti lentelės išdėstymo ypatybes. |
display: table-cell; | Apibrėžia elementą kaip lentelės langelį, įgalindamas vertikalaus lygiavimo ypatybes. |
vertical-align: middle; | Vertikaliai centruoja turinį lentelės langelio elemente. |
line-height: 170px; | Nustato eilutės aukštį, lygų sudėtinio rodinio aukščiui, kad tekstas būtų vertikaliai centre. |
Vertikalaus teksto centravimo būdai naudojant CSS
Pirmajame scenarijaus pavyzdyje mes naudojame apibrėžti lanksčią talpyklą. Tai leidžia naudoti „Flexbox“ išdėstymo ypatybes. Pagal nustatymą ir , galime horizontaliai ir vertikaliai centruoti tekstą viduje
Antrajame scenarijaus pavyzdyje naudojamas CSS tinklelio išdėstymas naudojant . Pagal nustatymą , tekstas tinklelio konteineryje centruojamas tiek horizontaliai, tiek vertikaliai. CSS Grid siūlo galingesnę ir lankstesnę žiniatinklio maketų kūrimo sistemą, palyginti su tradiciniais metodais. Tai suteikia galimybę lengvai kurti sudėtingus, jautrius dizainus. The komanda yra glaustas būdas vertikaliai ir horizontaliai centruoti, supaprastinant kodą ir pagerinant skaitomumą.
Pažangios CSS technologijos vertikaliam centravimui
Trečiame scenarijuje naudojame lentelės rodymo metodą. Nustatymas ant konteinerio ir ant pseudoelemento, sukurto su leidžia mums naudotis vertical-align: middle; nuosavybė. Šis metodas imituoja lentelės langelių elgseną, todėl turinį galima centruoti vertikaliai. Nors šiuolaikiniame žiniatinklio dizaine šis metodas naudojamas rečiau, jis gali būti naudingas palaikant suderinamumą su senesnėmis naršyklėmis arba dirbant su senu kodu. Tai patikimas būdas sutelkti turinį nepasikliaujant naujesnėmis išdėstymo sistemomis.
Ketvirtajame scenarijaus pavyzdyje naudojamas nuosavybė. Nustatydami lygus konteinerio aukščiui, tekstas yra vertikaliai centre. Ši technika yra paprasta ir efektyvi vienos eilutės tekstui. Tačiau jis gali netikti kelių eilučių tekstui arba dinaminiam turiniui, kai gali keistis sudėtinio rodinio aukštis. Nepaisant savo apribojimų, metodas yra greitas ir paprastas sprendimas vertikaliai centruoti tekstą paprastuose scenarijuose.
„Flexbox“ naudojimas vertikaliam centravimui
CSS Flexbox
#box {
height: 170px;
width: 270px;
background: #000;
font-size: 48px;
color: #FFF;
display: flex;
justify-content: center;
align-items: center;
}
<div id="box">Lorem ipsum dolor sit</div>
Tinklelio naudojimas vertikaliam centravimui
CSS tinklelis
#box {
height: 170px;
width: 270px;
background: #000;
font-size: 48px;
color: #FFF;
display: grid;
place-items: center;
}
<div id="box">Lorem ipsum dolor sit</div>
Lentelės ekrano naudojimas vertikaliam centravimui
CSS lentelės ekranas
#box {
height: 170px;
width: 270px;
background: #000;
font-size: 48px;
color: #FFF;
display: table;
}
#box::before {
content: "";
display: table-cell;
vertical-align: middle;
}
#box > div {
display: inline-block;
vertical-align: middle;
}
<div id="box"><div>Lorem ipsum dolor sit</div></div>
Linijos aukščio naudojimas vertikaliam centravimui
CSS linijos aukštis
#box {
height: 170px;
width: 270px;
background: #000;
font-size: 48px;
color: #FFF;
line-height: 170px;
text-align: center;
}
<div id="box">Lorem ipsum dolor sit</div>
Vertikalaus centravimo CSS transformacijos tyrinėjimas
Kitas veiksmingas būdas vertikaliai centruoti tekstą a naudoja CSS nuosavybė. Sujungus su transform: translateY(-50%);, galime pasiekti tikslų vertikalų išlygiavimą. Pirma, yra nustatytas veikti kaip atskaitos taškas. Tada vaikas elementas su yra 50 % pirminio sudėtinio rodinio viršuje. Galiausiai, taikymas transform: translateY(-50%); perkelia elementą į viršų per pusę jo aukščio, puikiai centruodamas jį vertikaliai.
Šis metodas suteikia didelį lankstumą ir puikiai tinka įvairių tipų turiniui, įskaitant tekstą ir vaizdus. Tai ypač naudinga dirbant su dinamišku turiniu, nes centravimo efektas išlieka nuoseklus, nepaisant turinio aukščio. Be to, derinant su kitomis CSS ypatybėmis leidžia kurti sudėtingesnius ir kūrybiškesnius išdėstymo dizainus. Nors šis metodas reikalauja šiek tiek daugiau kodo, palyginti su „Flexbox“ ar „Grid“, jis siūlo tikslią elementų padėties valdymą.
- Koks yra lengviausias būdas vertikaliai centruoti tekstą div?
- Naudojant su ir dažnai yra lengviausias ir efektyviausias būdas.
- Kaip vertikaliai centruoti tekstą senesnėse naršyklėse?
- Naudojant lentelės rodymo metodą su ir gali padėti pasiekti vertikalų centravimą senesnėse naršyklėse.
- Ar CSS tinklelis gali būti naudojamas tekstui centruoti vertikaliai?
- Taip, CSS tinklelis gali centruoti tekstą vertikaliai ir .
- Ar galima vertikaliai centruoti kelių eilučių tekstą?
- Taip, naudojant „Flexbox“ arba „CSS Grid“ galima lengvai centruoti kelių eilučių tekstą vertikaliai konteineryje.
- Kaip vertikaliai centruoti tekstą su žinomu konteinerio aukščiu?
- Galite nustatyti ypatybę, kad ji atitiktų sudėtinio rodinio aukštį ir efektyviai centruotų tekstą.
- Ką daryti, jei konteinerio aukštis yra dinamiškas?
- Naudojant Flexbox, Grid arba savybė užtikrina nuoseklų vertikalų centravimą, net ir esant dinaminiam konteinerio aukščiui.
- Ar yra kokių nors naudojimo trūkumų ?
- Nors tai veiksminga, ji reikalauja, kad tėvai turėtų ir gali būti šiek tiek sudėtingiau įdiegti, palyginti su „Flexbox“ ar „Grid“.
- Kaip vertikaliai centruoti tekstą interaktyviame dizaine?
- Labai rekomenduojama naudoti „Flexbox“ arba „CSS Grid“ reaguojant į dizainą, nes jie puikiai prisitaiko prie skirtingų ekranų dydžių ir orientacijų.
Vertikalus teksto centravimas elemente „div“ gali būti atliktas keliais efektyviais metodais. Šiuolaikinės technologijos, tokios kaip „Flexbox“ ir „Grid“, siūlo didžiausią lankstumą ir lengvumą. Senesni metodai, tokie kaip lentelės rodymas ir linijos aukštis, vis dar gali būti naudingi tam tikrais atvejais. Suprasdami ir taikydami šiuos skirtingus metodus, kūrėjai gali užtikrinti, kad jų turinys būtų vizualiai patrauklus ir tinkamai suderintas įvairiuose įrenginiuose ir naršyklėse.