亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

CSS布局基礎(chǔ)BFC

  發(fā)布時間:2016-07-14 17:05:09   作者:佚名   我要評論
這篇文章主要介紹了CSS布局基礎(chǔ)BFC 的相關(guān)資料,需要的朋友可以參考下

 BFC是什么?

第一次看到這個名詞,我是拒絕的,css什么時候還有這個東西?于是迫不及待的google了一下,才發(fā)現(xiàn)原來它無時無刻不在我們的css當中,只不過它并不是一個屬性,不需要我們平常使用手寫罷了。但是它的重要性確是杠杠的,可以這么說,沒有它就就沒有什么css布局 BFC,全稱 Block Formatting Context,翻譯成塊級格式化上下文,它就是一個環(huán)境,HTML元素在這個環(huán)境中按照一定規(guī)則進行布局。一個環(huán)境中的元素不會影響到其它環(huán)境中的布局。

看一大堆文字可能有點抽象,現(xiàn)在拿個js函數(shù)來比喻說明一下吧,我們現(xiàn)在有一個叫做bfc的函數(shù),而一個函數(shù)就是一個塊級作用域,這里面所有的變量申明、運行都在這個塊級作用域內(nèi)進行。理所當然,一個環(huán)境中的變量不會影響到其它環(huán)境變量。

CSS Code復(fù)制內(nèi)容到剪貼板
  1.  var box =1;   
  2. function bfc(){   
  3.     var box = "2";   
  4.     console.log(box);   
  5. }   
  6. bfc();//2   
  7. console.log(box)//1   

所以,我們是不是可以這樣理解:所謂的BFC就是css屬性的執(zhí)行域?
 
BFC的生成
 
既然js可以通過函數(shù)等方法來實現(xiàn)塊級作用域,我想那css肯定也是可以通過一些手段來實現(xiàn)BFC的。
 這里BFC的官方文檔寫到:
 
Floats, absolutely positioned elements, block containers (such as inline-blocks, table-cells, and table-captions) that are not block boxes, and block boxes with ‘overflow’ other than ‘visible’ (except when that value has been propagated to the viewport) establish new block formatting contexts for their contents.
 
從這段描述可以清楚知道,以下方法可以創(chuàng)建一個新的塊級執(zhí)行上下文(BFC):

 1.浮動元素、
 2.絕對定位元素,
 3.塊級元素以及塊級容器(比如inline-block、table-cell、table-capation)
 4.overflow值不為visible的塊級盒子
 
當然,root元素會自動生成一個BFC,這個應(yīng)該很好理解,畢竟需要一個根BFC來布局
 
執(zhí)行規(guī)則
 
既然存在了執(zhí)行環(huán)境,那肯定會存在執(zhí)行規(guī)則。BFC的
 
1.在一個塊級排版上下文中,盒子是從包含塊頂部開始,垂直的一個接一個的排列的。每個盒子的左外邊是觸碰到包含塊的左邊的(對于從右向左的排版,則相反)
 
這個應(yīng)該不難理解。就是我們?nèi)绻诶飳憥讉€<div>,它會依次垂直排列,并且都是在頁面的最左邊(對于從右向左的排版,則相反)。
 
2.相鄰兩個盒子之間的垂直的間距是被margin屬性所決定的,在一個塊級排版上下文中相鄰的兩個塊級盒之間的垂直margin是折疊的。
 
這句描述是不是超級熟悉,這不是我css常見的邊距折疊問題嗎?現(xiàn)在知道它出自哪里了吧,就是這里。下面的倆個盒子各有上下20px的間距,加起來應(yīng)該有40px,但顯然,現(xiàn)在只有20px;

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style>   
  2. .top{   
  3.     width:100px;   
  4.     height:100px;   
  5.     background:#000;   
  6.     margin:20px 0;   
  7. }   
  8. .bottombottom{   
  9.     width:100px;   
  10.     height:100px;   
  11.     background:#000;   
  12.     margin:20px 0;   
  13. }   
  14. </style>   
  15. <div  class="top"></div>   
  16. <div  class="bottom"></div>   

發(fā)生邊距折疊是因為同一個BFC的關(guān)系(根BFC)。既然知道原因,解決就好辦了,讓他們倆個不在同一個BFC就ok啦。
3. BFC就是頁面上的一個隔離的獨立容器,容器里面的子元素不會影響到外面的元素。
 
通過這條屬性,我們又可以想到哪些呢。對,浮動元素的塌陷問題。我們知道,一個元素中的子元素浮動了,這個父元素就會發(fā)生高度塌陷問題。下例中一旦內(nèi)部的紅色元素浮動,藍色的盒子就無法被撐起,高度會變成0。

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style>   
  2. .wrap{   
  3.     width:150px;   
  4.     background:#ADD9E6;   
  5.     margin:20px 0;   
  6. }   
  7. .in{   
  8.     width:100px;   
  9.     height:100px;   
  10.     background:#FFCCCC;   
  11.     margin:20px 0;   
  12.     //float:left;   
  13. }   
  14. </style>   
  15. <div class="wrap"><div class="in"></div></div>   

現(xiàn)在我們知道了,這是因為浮動元素創(chuàng)建了一個新的BFC,成為了一個獨立的容器,不會影響到外面的父元素了。它的定位規(guī)則不再受制于這個父元素了。如何解決這一問題?我們知道只要在在父元素加上overflow:hidden可以清除浮動。但是這又是為什么?
 
其實,這就是前面提到的overflow:hidden可以生成一個新的BFC,而這個浮動的子元素,被它所包含了,從而成為一個獨立容器,它的float外溢不了了,外面的元素不再受其浮動的影響,從而達到了清除浮動的作用。

相關(guān)文章

  • 10分鐘理解CSS BFC原理及其應(yīng)用

    這篇文章主要介紹了10分鐘理解BFC原理及其應(yīng)用的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-01
  • 淺析CSS里的BFC和IFC的用法

    這篇文章主要介紹了淺析CSS里的BFC和IFC的用法的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-30
  • 淺談CSS潛藏著的BFC

    這篇文章主要介紹了淺談CSS潛藏著的BFC的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-08
  • css布局之BFC模式(block formatting context)

    這篇文章主要介紹了css布局之BFC模式(block formatting context),通過BFC盒子的一些特性和應(yīng)用場景解釋了BFC模式,具體操作步驟大家可查看下文的詳細講解,感興趣的小伙
    2017-08-16
  • CSS使用BFC規(guī)則布局引發(fā)外層div包裹內(nèi)層div的處理方法

    BFC情況下人們通常在div中使用float和margin,這會經(jīng)常出現(xiàn)一些問題,這里就來看一下CSS使用BFC規(guī)則布局引發(fā)外層div包裹內(nèi)層div的處理方法,需要的朋友可以參考下.
    2016-06-03
  • CSS理解塊級格式上下文(BFC)

    BFC(Block formatting context)直譯為"塊級格式化上下文"。它規(guī)定了內(nèi)部的Block-level Box如何布局,并且與這個區(qū)域外部毫不相干.接下來通過本文給大家介紹CSS理
    2018-02-22

最新評論