浮動定位BFC邊距合并

浮動元素有什么特征?

特征

  • 元素浮動之后不占據原來的位置
  • 浮動的盒子在一行上顯示
  • 行內元素浮動之后轉換為具備有塊級元素的特征,可以設置寬高

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

  • 如果父容器的子元素都是浮動元素,如果父容器沒有定義高度,那么父容器會失去高度,在浮動元素之外。
  • 對于普通元素,普通元素會感知不到浮動元素當然存在,如果寬高合適,后面的元素會占據浮動元素原來的位置
  • 對于文字來說,能感知到浮動元素的存在,如果位置足夠,就能夠實現文本繞圖的效果

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

清除浮動不是不要浮動,而是清楚浮動帶來的不利影響

方法

  • 使父元素形成新的BFC,可以使用overflow:hidden/auto/scroll
    display:inline-block float:方位等等
  • 使用偽元素清楚浮動,如
.clearfix{zoom:1;}
.clearfix:after{ 
content:"";
display:block;
visible:hidden;
clear:both;
}

然后在需要清除浮動的元素進行調用。

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

  • inherit 規定應該從父元素繼承 position 屬性的值
  • static默認值,沒有定位,元素出現在正常的流中(忽略 top, bottom, left, right 或者 z-index 聲明)
  • relative生成相對定位的元素,相對于元素本身正常位置進行定位,因此,left:20px會向元素的 left 位置添加20px
  • absolute生成絕對定位的元素,相對于static定位以外的第一個祖先元素(offset parent)進行定位,元素的位置通過 left, top, right以及 bottom 屬性進行規定
  • fixed生成絕對定位的元素,相對于瀏覽器窗口進行定位。元素的位置通過 left, top, right 以及 bottom 屬性進行規定
  • stickyCSS3新屬性,表現類似position:relative和position:fixed的合體,在目標區域在屏幕中可見時,它的行為就像position:relative; 而當頁面滾動超出目標區域時,它的表現就像position:fixed,它會固定在目標位置
    普通流與相對定位
    CSS有三種基本的定位機制:普通流,相對定位和絕對定位
    普通流是默認定位方式,在普通流中元素框的位置由元素在html中的位置決定,元素position屬性為static或繼承來的static時就會按照普通流定位,這也是我們最常見的方式
    相對定位比較簡單,對應position屬性的relative值,如果對一個元素進行相對定位,它將出現在他所在的位置上,然后可以通過設置垂直或水平位置,讓這個元素相對于它自己移動,在使用相對定位時,無論元素是否移動,元素在文檔流中占據原來空間,只是表現出來的位置會改變

絕對定位與固定定位相對定位可以看作特殊的普通流定位,元素位置是相對于它在普通流中位置發生變化,而絕對定位使元素的位置與文檔流無關,也不占據文檔流空間,普通流中的元素布局就像絕對定位元素不存在一樣

絕對定位的元素的位置是相對于距離最近的非static祖先元素位置決定的。如果元素沒有已定位的祖先元素,那么他的位置就相對于初始包含塊html來定位

因為絕對定位與文檔流無關,所以絕對定位的元素可以覆蓋頁面上的其他元素,可以通過z-index

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

  • z-index 屬性指定一個元素的堆疊順序。因為絕對定位的元素脫離了普通流,所以絕對定位的元素可以覆蓋頁面上的其它元素。這時可以通過給元素設置z-index屬性來控制疊放順序,擁有更高堆疊順序的元素總是會處于堆疊順序較低的元素的前面。
  • z-index有三個屬性
    auto 默認。堆疊順序與父元素相等。
    number設置元素的堆疊順序。
    inherit規定應該從父元素繼承 z-index 屬性的值。

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

position:relative;只相對自己原本位置發生偏移,不影響其它普通流中元素的位置。margin:除了讓元素自身發生偏移還影響其它普通流中的元素。

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

BFC是指塊級元素格式化,在同一個BFC中,元素會遵守一些規則,如從上到下排列,邊距合并等,如果是相鄰兩個元素分別處于兩個BFC當中,則一般不會遵循這些規則。
作用:
(1) 解決margin重疊問題,在同一個BFC中,相鄰元素之間的邊距會合并,如果把這兩個元素分別放在兩個BFC中,name他們的邊距就不會合并。一般應用于嵌套關系。
(2)清除浮動。BFC不會重疊浮動元素。

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

外邊距合并出現的三個場景。

  • 同一個BFC,且同處于普通流中的垂直相鄰元素外邊距合并。
  • 父子元素的外邊距合并。
  • 空元素的外邊距合并。

合并規則:

  • 兩個margin都是正值的時候,取兩者的最大值;
  • 當 margin 都是負值的時候,取的是其中絕對值較大的,然后,從0位置,負向位移;
  • 當有正有負的時候,先取出負 margin 中絕對值中最大的,然后,和正 margin 值中最大的 margin 相加。
  • 所有毗鄰的margin要一起參與運算,不能分步進行
    不讓相鄰元素外邊距合并的方法:
  • 被非空內容、padding、border 或 clear 分隔開。
  • 不在一個普通流中或一個BFC中。
  • margin在垂直方向上不毗鄰。

總結:

  • 這些margin都處于普通流中,并在同一個BFC中;
  • 這些margin沒有被非空內容、padding、border 或 clear 分隔開;
  • 這些margin在垂直方向上是毗鄰的,包括以下幾種情況:

一個box的top margin與第一個子box的top margin
一個box的bottom margin與最后一個子box的bottom margin,但須在該box的height 為auto的情況下
一個box的bottom margin與緊接著的下一個box的top margin
一個box的top margin與其自身的bottom margin,但須滿足沒創建BFC、零min-height、零或者“auto”的height、沒有普通流的子元素。

  • 例外的情況

根元素的外邊距不會參與折疊
不設置任何屬性的空span和空div不影響任何布局,可以無視之。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,327評論 6 537
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,996評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,316評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,406評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,128評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,524評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,576評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,759評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,310評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,065評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,249評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,821評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,479評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,909評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,140評論 1 290
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,984評論 3 395
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,228評論 2 375