浮動定位BFC邊距合并

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

浮動元素不在文檔的普通流中,它可以根據float屬性值而左右移動,直到它的外邊緣碰到包含框或者另一個浮動元素的框的邊緣才停止移動。

  • 對父容器的影響:如果父容器的子元素都是浮動元素,那么父容器會失去高度,在浮動元素之外。視覺上,父容器沒有包含住浮動的子元素。
  • 其它浮動元素的影響:如果包含塊太窄無法容納水平排列的全部浮動元素,那么其它浮動元素會向下移動,直到有足夠的空間,而如果浮動元素的高度不同,那么向下移動的時候可能會被卡住。
  • 普通元素的影響:普通元素會視浮動元素不見,占據浮動元素原有的位置,但會被浮動元素遮罩。
  • 對文字的影響:文字會感知到浮動元素的存在,會留出空間,形成環繞效果。

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

1.清除浮動指清除掉元素float屬性。

1)添加額外標簽
通過在浮動元素末尾添加一個空的標簽,例如 <div style=”clear:both”></div>
優點:比空標簽方式語義稍強,代碼量較少 。
缺點:同樣有違結構與表現的分離,不推薦使用 。
2 )利用BFC來清除浮動。
因為BFC可以包含浮動,因此可以讓父元素生成一個新的BFC從而包圍浮動的子元素。
可以對父元素設定以下樣式之一生成新BFC。

  • float: left | right;
  • overflow: hidden | auto | scroll;
  • display: table-cell | table-caption | inline-block;
  • position: absolute | fixed;
    3)使用:after 偽元素
    .clearfix:after {content:""; display:block; clear:both; }
    .clearfix { *zoom:1; }
    由于IE6-7不支持:after,使用 zoom:1觸發 hasLayout。
    優點:結構和語義化完全正確,代碼量居中
    缺點:復用方式不當會造成代碼量增加

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

有6種定位方式:

  • inherit:從父元素繼承;
  • static:默認值,沒有定位,元素出現在正常的文檔流中。參考點是文檔流中的位置。
  • relative:相對定位。相對于元素本身正常位置進行定位,通過top、bottom、left、right屬性來設置偏移量。使用場景:為絕對定位設定參照物或對元素自身位置進行局部調整。
  • absolute:絕對定位。相對于static定位意外的第一個祖先元素進行定位,若都沒有發現則以html標簽為參考進行定位。使用場景:當想讓元素參照特定參照物進行定位時使用。
  • fixed:固定定位。生成絕對定位元素,相對于viewport進行定位。
  • sticky:對象在常態時遵循普通流。它就像是relative和fixed的合體,當在屏幕中時按常規流排版,當卷動到屏幕外時則表現如fixed。

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

當你定義的CSS中有position屬性值為absolute、relative或fixed,用z-index此取值方可生效。此屬性參數值越大,則被層疊在最上面。

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

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

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

  1. BFC就是 Block formatting contexts (塊級格式化上下文)。
  2. 如何生成BFC呢?
  • float 除了none以外的值
  • overflow 除了visible 以外的值(hidden,auto,scroll )
  • display (table-cell,table-caption,inline-block)
  • position(absolute,fixed)
  1. BFC作用:
    1)塊級格式化上下文會阻止外邊距疊加
    當兩個相鄰的塊框在同一個塊級格式化上下文中時,它們之間垂直方向的外邊距會發生疊加。換句話說,如果這兩個相鄰的塊框不屬于同一個塊級格式化上下文,那么它們的外邊距就不會疊加。
    2)塊級格式化上下文不會重疊浮動元素
    根據規定,一個塊級格式化上下文的邊框不能和它里面的元素的外邊距重疊。這就意味著瀏覽器將會給塊級格式化上下文創建隱式的外邊距來阻止它和浮動元素的外邊距疊加。由于這個原因,當給一個挨著浮動的塊級格式化上下文添加負的外邊距時將會不起作用(Webkit和IE6在這點上有一個問題——可以看這個測試用例)。
    3)塊級格式化上下文通常可以包含浮動
    詳見: W3C CSS2.1 - 10.6.7 'Auto' heights for block formatting context roots

通俗地來說:創建了 BFC的元素就是一個獨立的盒子,里面的子元素不會在布局上影響外面的元素,反之亦然,同時BFC任然屬于文檔中的普通流。

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

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

(1)兩個兄弟元素在垂直方向上合并外邊距,取較大值進行合并。
代碼1
這時兩個div在垂直距離上的外邊距進行了合并,合并后的值是20px。
(2)父子元素間沒有阻擋(如:邊框、非空內容、padding等)時發生上和/或下外邊距合并。
代碼2
這時就會發生合并。合并后的外邊距是30px。
(3)外邊距自己和自己合并
如果一個元素沒有邊框和填充內容,但有上下外邊距,這時它的上下外邊距會合并
代碼3
這時上下外邊距合并成50px。
除此之外,若該元素垂直方向上的兄弟元素也有外邊距,那么垂直方向的外邊距依舊會發生合并。
代碼4
此時,外邊距合并成80px。

3.阻止嵌套元素的外邊距合并形成BFC可以阻止外邊柜合并或者元素上加上border或者padding。

8.代碼

1.實現如下alert效果,效果范例79
作業1

2.實現如下表單效果, 效果范例89
作業2

3.實現如下模態框效果, 效果范例83
作業3

4.實現如下導航欄效果,效果范例100
作業4

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

推薦閱讀更多精彩內容

  • relative:生成相對定位的元素,通過top,bottom,left,right的位置相對于其正常位置進行定位...
    zx9426閱讀 954評論 0 2
  • 浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 特征: 脫離正常文檔流,沿其容器的左側...
    _Dot912閱讀 724評論 0 3
  • 1.浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 浮動元素不在文檔的普通流中,它可以...
    饑人谷_Young丶K閱讀 442評論 0 0
  • 1. 浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 浮動元素特征:使元素脫離文檔流,...
    蕭雪圣閱讀 188評論 0 1
  • 1.浮動元素有什么特征?對父容器、其他浮動元素、普通元素、文字分別有什么影響? 任何定義為float的元素,都可以...
    QQQQQCY閱讀 268評論 0 0