锐客直播_锐客直播app官方正版下载_锐客直播直播视频在线观看免费版下载

400-650-7353
您所在的位置:首頁 > IT干貨資料 > web前端 > 【W(wǎng)eb前端基礎(chǔ)知識(shí)】關(guān)于css居中

【W(wǎng)eb前端基礎(chǔ)知識(shí)】關(guān)于css居中

  • 發(fā)布: Web前端培訓(xùn)
  • 來源:Web前端干貨資料
  • 2020-08-26 18:39:25
  • 閱讀()
  • 分享
  • 手機(jī)端入口

3. transform + absolute

  absolute定位元素的left、top屬性是子元素的左邊界、上邊界相對(duì)父元素進(jìn)行定位;transform是CSS3中非常強(qiáng)大的一個(gè)屬性,可以接收多個(gè)屬性值,包括旋轉(zhuǎn)、縮放、平移等多種功能。這里使用二者配合,先將子元素左上定點(diǎn)定位到父元素中心點(diǎn),再使用transform將子元素中心點(diǎn)移動(dòng)到父元素的中心點(diǎn)即可:

  1. .container { 
  2.   width: 300px; 
  3.   height: 300px; 
  4.   position: relative; 
  5.   border: 1px solid red; 
  6.  
  7. .content { 
  8.   position: absolute; 
  9.   left: 50%; 
  10.   top: 50%; 
  11.   transform: translate(-50%, -50%);   
  12.   border: 1px solid green; 

  這個(gè)方法有個(gè)小缺陷,就是translate函數(shù)的參數(shù),最后的計(jì)算值不能為小數(shù),否則有的瀏覽器渲染出來效果會(huì)模糊,所以使用本方法的話最好設(shè)置一下寬高為偶數(shù)。

4. absolute+margin負(fù)值

  與上一種方法很類似,上一種方法是使用transform將元素向左上平移,本方法則是使用margin負(fù)值的方式將元素拉向左上角。

代碼:

  1. .container { 
  2.   width: 300px; 
  3.   height: 300px; 
  4.   position: relative; 
  5.   border: 1px solid red; 
  6.  
  7. .content { 
  8.   position: absolute; 
  9.   left: 50%; 
  10.   top: 50%; 
  11.   width: 200px; 
  12.   height: 100px; 
  13.   margin-top: -50px; 
  14.   margin-left: -100px; 
  15.   border: 1px solid green; 

5. absolute + calc

  從上兩種方法可以看到,absolute設(shè)置了left和top再通過平移或者margin將元素重新定位回去。如果我們直接可以計(jì)算出正確的left和top值,豈不是一次到位?calc函數(shù)正有此功能,當(dāng)然我們需要知道子元素的寬高:

  1. .container { 
  2.   width: 300px; 
  3.   height: 300px; 
  4.   border: 1px solid red; 
  5.   text-align: center; 
  6.   position: relative; 
  7.  
  8. .content { 
  9.   position: absolute; 
  10.   border: 1px solid green; 
  11.   width: 200px; 
  12.   height: 100px; 
  13.   left: calc(50% - 100px); 
  14.   top: calc(50% - 50px); 

6. line-height + vertical-align

  vertical-align是一個(gè)作用于內(nèi)聯(lián)元素的屬性。內(nèi)聯(lián)元素的特性是會(huì)和其它內(nèi)聯(lián)元素或者文字在同一行顯示,但是默認(rèn)情況下是與父元素“基線對(duì)齊”的。這里的的基線指的是父元素每一行中的一個(gè)垂直位置,是英文x下邊緣所在的水平, 通過設(shè)置vertical-align為middle可以將內(nèi)聯(lián)元素的中部對(duì)齊父元素的中部(基線+字母x的一半高度)。所以可以利用這一點(diǎn),將父元素的行高設(shè)置為其自身高度,然后將子元素與父元素中線對(duì)齊,即可實(shí)現(xiàn)垂直居中。

代碼:

  1. .container { 
  2.   width: 300px; 
  3.   height: 300px; 
  4.   border: 1px solid red; 
  5.   line-height: 300px; 
  6.   text-align: center; 
  7.  
  8. .content { 
  9.   display: inline-block; 
  10.   line-height: 1.5; 
  11.   border: 1px solid green; 
  12.   vertical-align: middle; 

 

文章“【W(wǎng)eb前端基礎(chǔ)知識(shí)】關(guān)于css居中”已幫助

>>本文地址:http://uj2y2uok.com/zhuanye/2020/53435.html

THE END  

聲明:本站稿件版權(quán)均屬中公教育優(yōu)就業(yè)所有,未經(jīng)許可不得擅自轉(zhuǎn)載。

1 您的年齡

2 您的學(xué)歷

3 您更想做哪個(gè)方向的工作?

獲取測(cè)試結(jié)果
  • 大前端大前端
  • 大數(shù)據(jù)大數(shù)據(jù)
  • 互聯(lián)網(wǎng)營(yíng)銷互聯(lián)網(wǎng)營(yíng)銷
  • JavaJava
  • Linux云計(jì)算Linux
  • Python+人工智能Python
  • 嵌入式物聯(lián)網(wǎng)嵌入式
  • 全域電商運(yùn)營(yíng)全域電商運(yùn)營(yíng)
  • 軟件測(cè)試軟件測(cè)試
  • 室內(nèi)設(shè)計(jì)室內(nèi)設(shè)計(jì)
  • 平面設(shè)計(jì)平面設(shè)計(jì)
  • 電商設(shè)計(jì)電商設(shè)計(jì)
  • 網(wǎng)頁設(shè)計(jì)網(wǎng)頁設(shè)計(jì)
  • 全鏈路UI/UE設(shè)計(jì)UI設(shè)計(jì)
  • VR/AR游戲開發(fā)VR/AR
  • 網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全
  • 新媒體與短視頻運(yùn)營(yíng)新媒體
  • 直播帶貨直播帶貨
  • 智能機(jī)器人軟件開發(fā)智能機(jī)器人
 

快速通道fast track

近期開班時(shí)間TIME