CSS浮動與定位

浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響?

浮動元素脫離了普通文檔流,文檔的普通流中的元素表現(xiàn)的就像浮動元素不存在一樣。浮動的框可以向左或向右移動,直到它的外邊緣碰到包含框或另一個浮動框的邊框為止。

  • 對父容器的影響:如果父容器的子元素都是浮動元素,那么父容器會失去高度。
  • 對其他浮動元素的影響:如果包含塊兒太窄無法容納水平排列的幾個浮動元素,那么其它浮動塊兒向下移動,直到有足夠的空間,如果浮動元素的高度不同,那么向下移動的時候可能被卡住。
  • 對普通元素的影響:因為浮動元素脫離了文檔的普通流,文檔的普通流中的元素表現(xiàn)的就像浮動元素不存在一樣。
  • 對文字的影響:文字會感應到浮動元素的存在,并產(chǎn)生文字環(huán)繞浮動元素的效果。

清除浮動指什么? 如何清除浮動? 兩種以上方法

清楚浮動指解決浮動元素父容器高度塌陷問題。

  1. 在父容器最后添加一個空div,并清理這個div。clear:both;
  2. 使父容器生成一個BFC,因為BFC可以包含浮動。
    規(guī)定滿足下列CSS聲明之一的元素便會生成BFC。
  • 根元素
  • float的值不為none
  • overflow的值不為visible
  • display的值為inline-block、table-cell、table-caption
  • position的值為absolute或fixed
  1. 通用的清除浮動方法。
 /*方法1*/
 .clearfix{
      *zoom:1;
  }
  .clearfix:after{ 
      content:"";
      display:block;
      clear:left;
  }

 /*方法2*/
  .clearfix{
    *zoom:1;
  }
  .clearfix:after{
    content:"";
      display:table;
      clear:both;
  }?

有幾種定位方式,分別是如何實現(xiàn)定位的,參考點是什么,使用場景是什么?

|定位方式|實現(xiàn)方式|參考點|使用場景|
| :--------- :|-----------|----------|------------|
|static|默認值,沒有定位,元素出現(xiàn)在正常的流中。|無||
|relative|相對定位,元素框偏移某個距離。元素仍保持其未定位前的形狀,它原本所占的空間仍保留。|元素本身位置|元素的偏移|
|absolute|絕對定位,元素框從文檔流中刪除,元素定位后生成一個塊級框,而不論原來它在正常流中生成何種類型的框。|距離最近的非static元素,否則為body|元素垂直水平居中|
|fixed|固定定位,生成絕對定位元素,但不隨著滾動條的移動而改變位置。|瀏覽器窗口|登錄框覆蓋層|


z-index 有什么作用? 如何使用?

z-index 屬性設置元素的堆疊順序。擁有更高堆疊順序的元素總是會處于堆疊順序較低的元素的前面。如果為正數(shù),則離用戶更近,為負數(shù)則表示離用戶更遠。Z-index 僅能在定位元素上奏效。


position:relative和負margin都可以使元素位置發(fā)生偏移?二者有什么區(qū)別

相對定位與負margin都可以是元素位置發(fā)生偏移。
區(qū)別:使用負margin的元素在文檔流中的位置會變動,而相對定位不會,只是顯示的位置發(fā)生變化。


BFC 是什么?如何生成 BFC?BFC 有什么作用?舉例說明

BFC的全稱是 Block Format Content,塊級格式化上下文。
規(guī)定滿足下列CSS聲明之一的元素便會生成BFC。

  • 根元素
  • float的值不為none
  • overflow的值不為visible
  • display的值為inline-block、table-cell、table-caption
  • position的值為absolute或fixed

BFC 作用

  • BFC會阻止垂直外邊距(margin-top、margin-bottom)折疊
    按照BFC的定義,只有同屬于一個BFC時,兩個元素才有可能發(fā)生垂直Margin的重疊,這個包括相鄰元素,嵌套元素,只要他們之間沒有阻擋(例如邊框,非空內(nèi)容,padding等)就會發(fā)生margin重疊。
    因此要解決margin重疊問題,只要讓它們不在同一個BFC就行了,但是對于兩個相鄰元素來說,意義不大,沒有必要給它們加個外殼,但是對于嵌套元素來說就很有必要了,只要把父元素設為BFC就可以了。這樣子元素的margin就不會和父元素的margin發(fā)生重疊
  • BFC不會重疊浮動元素
  • BFC可以包含浮動。

在什么場景下會出現(xiàn)外邊距合并?如何合并?如何不讓相鄰元素外邊距合并?給個父子外邊距合并的范例

外邊距合并指的是,當兩個垂直外邊距相遇時,它們將形成一個外邊距。
合并后的外邊距的高度等于兩個發(fā)生合并的外邊距的高度中的較大者。

  • 相鄰元素外邊距合并。第一個元素的下外邊距與第二個元素的上外邊距會發(fā)生合并。


  • 父子外邊距合并。假設沒有內(nèi)邊距或邊框把外邊距分隔開,那么它們的上和/或下外邊距也會發(fā)生合并。


  • 空元素外邊距合并。假設有一個空元素,它有外邊距,但是沒有邊框或填充。在這種情況下,上外邊距與下外邊距就碰到了一起,它們會發(fā)生合并。



    如果這個外邊距遇到另一個元素的外邊距,它還會發(fā)生合并:



代碼1
代碼2
代碼3
代碼4

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,806評論 1 92
  • 1.浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 答:浮動模型也是一種可視化格式模型...
    饑人谷_牛牛閱讀 406評論 0 0
  • 1.浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 浮動模型也是一種可視化格式模型,浮...
    謹言_慎行閱讀 425評論 0 3
  • 問答 1. 浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 浮動元素有什么特征floa...
    cheneyzhangch閱讀 317評論 0 0
  • 浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 4.對普通元素:普通元素將不能感知到浮...
    l_meng閱讀 318評論 0 0