CSS實(shí)現(xiàn)浮動(dòng)效果

一、浮動(dòng)
早期用于實(shí)現(xiàn)文字環(huán)繞圖片(環(huán)繞布局),現(xiàn)在用于讓元素并列布局(塊元素并排)。浮動(dòng)元素會(huì)脫離文檔流,后邊的元素會(huì)把空出來的位置補(bǔ)上去。但是又因?yàn)楦?dòng)元素的層級(jí)高,所以會(huì)將未浮動(dòng)的元素進(jìn)行覆蓋,但是文字不會(huì)。
float
:none
無浮動(dòng),left
左浮動(dòng),right
右浮動(dòng)。
1、css布局的三種機(jī)制
- 標(biāo)準(zhǔn)文檔流,也叫標(biāo)準(zhǔn)流,普通流。主要實(shí)現(xiàn)上下布局,也就是頁面布局的默認(rèn)效果。
- 浮動(dòng)流,通過
float
實(shí)現(xiàn)并列顯示的布局。 - 定位流,通過
position
實(shí)現(xiàn)元素的層疊顯示的布局。
2、浮動(dòng)布局的特點(diǎn)
(1)浮動(dòng)元素會(huì)以頂對(duì)齊,且沒有縫隙緊挨著的方式進(jìn)行顯示。
(2)如果元素集體右浮動(dòng),顯示的順序會(huì)發(fā)生顛倒。
<head> <style> .demo1,.demo2{ width: 100px; height: 100px; float: right; } .demo1{ background-color: pink; } .demo2{ background-color: yellowgreen; } </style> </head> <body> <div class="box"> <p class="demo1">1</p> <p class="demo2">2</p> </div> </body>
(3)浮動(dòng)的元素會(huì)因?yàn)楫?dāng)前容器的橫向距離不足以擺放的時(shí)候,而發(fā)生換行。
如果元素的高度都是相等的,那就是另起一行的效果;如果元素的高度呈階梯狀,后續(xù)的元素在頂對(duì)齊放不下的情況下,會(huì)向下落到第一個(gè)障礙處停下來,且其之后的元素會(huì)排在它的后面。
<head> <style> .box{ width: 1000px; /* border: 1px solid #000; */ margin: 100px auto; } p{ float: left; } .demo1{ width: 400px; height: 100px; background-color: pink; } .demo2{ width: 400px; height: 50px; background-color: yellowgreen; } .demo3{ width: 100px; height: 30px; background-color: bisque; } .test{ width: 300px; height: 100px; background: skyblue; } .demo4{ width: 80px; height: 50px; background-color: purple; } </style> </head> <body> <div class="box"> <p class="demo1"></p> <p class="demo2"></p> <p class="demo3"></p> <p class="test"></p> <p class="demo4"></p> </div> </body>
上述代碼給父元素設(shè)置的寬度為1000px,粉色、綠色、肉色的盒子加在一起已經(jīng)900px了,不足以放下藍(lán)色盒子600px,所以放到了下層,而紫色盒子也跟在其后,即使第一行有足夠的空間。
(4)浮動(dòng)元素脫離文檔流,提升元素的層級(jí)。
<head> <style> *{ margin: 0; padding: 0; } .box{ width: 300px; /* border: 1px solid #000; */ margin: 100px auto; } p{ width: 100px; height: 100px; } .demo1{ background-color: pink; } .demo2{ width: 50px; height: 50px; background-color: yellowgreen; float: left; } .demo3{ background-color: skyblue; } </style> </head> <body> <div class="box"> <p class="demo1"></p> <p class="demo2"></p> <p class="demo3"></p> </div> </body>
綠色盒子添加浮動(dòng)后,脫離了文檔流,浮在了藍(lán)色盒子的上面。
(5)實(shí)現(xiàn)并列布局的元素都要增加浮動(dòng)屬性。
(6)浮動(dòng)的元素設(shè)置 margin:0 auto 無效。
<head> <style> *{ margin: 0; padding: 0; } .box{ width: 100px; height: 100px; background-color: pink; margin: 0 auto; float: left; } </style> </head> <body> <div class="box"></div> </body>
可以看出當(dāng)我們添加浮動(dòng)屬性之后,margin:0 auto
居中失效。
(7)浮動(dòng)的元素會(huì)轉(zhuǎn)變成塊元素。
<head> <style> span{ background-color: pink; padding: 30px; float: left; } </style> </head> <body> <span></span> </body>
這里可以看出原本的行內(nèi)元素在添加浮動(dòng)后,可以設(shè)置padding
值,同樣也可以設(shè)置寬高。沒設(shè)置寬高的時(shí)候,寬高會(huì)根據(jù)內(nèi)容自動(dòng)撐開,而不是顯示獨(dú)占一行。
二、浮動(dòng)對(duì)元素的影響及解決方法
1、浮動(dòng)對(duì)元素的影響
- 子元素浮動(dòng)會(huì)引起父元素的高度塌陷。
- 塊元素浮動(dòng)之后,默認(rèn)寬度不會(huì)顯示成父元素100%的效果了,而是靠內(nèi)容撐開,但是設(shè)置寬高依然有效。
- 行內(nèi)元素、行內(nèi)塊元素增加浮動(dòng)會(huì)被隱性轉(zhuǎn)換成塊元素。
<head> <style> .wrap{ width: 300px; border: 1px solid #000; } .box{ width: 100px; height: 100px; background-color: pink; float: left; } </style> </head> <body> <div class="wrap clearFix"> <p class="box"></p> </div> </body>
2、解決高度塌陷的方法
(1)給父元素設(shè)置定高。
但是不能自適應(yīng)高度,局限性較大,不推薦。
(2)開啟BFC(塊級(jí)格式化上下文)
給父元素添加overfloat:hidden
。因?yàn)楦冈卦跊]設(shè)置高度時(shí),不知道在哪個(gè)位置隱藏。該方法前提是父元素不能設(shè)置定高,相對(duì)推薦。
.wrap{ width: 300px; border: 1px solid #000; overflow: hidden; }
- 給父元素添加浮動(dòng)。但是浮動(dòng)會(huì)脫離文檔流,對(duì)頁面的影響較大,而且還可能會(huì)引起新的塌陷問題。不推薦。
- 給父元素添加絕對(duì)定位或固定定位。但也會(huì)脫離文檔流,造成新的頁面問題,不推薦。
(3)改變父元素的類型為inline-block
因?yàn)楦?dòng)只對(duì)塊元素有效。但是行內(nèi)塊元素會(huì)因?yàn)閾Q行符有留白。而且margin:0 auto
不能居中顯示,這時(shí)想要居中可以給父元素設(shè)置text-align:center
。
(4)清除浮動(dòng)clear(額外標(biāo)簽法)
在浮動(dòng)元素的后面添加一個(gè)空白標(biāo)簽,給它設(shè)置清除浮動(dòng)屬性,從而撐開父元素的高度。
清除浮動(dòng)是設(shè)置給被影響的元素,不是設(shè)置給浮動(dòng)的元素。
該屬性只對(duì)塊元素生效。
clear
:none
默認(rèn)值,會(huì)被浮動(dòng)元素遮擋;left
不會(huì)被向左浮動(dòng)的元素遮擋,顯示在浮動(dòng)元素的下面;right
不會(huì)被向右浮動(dòng)的元素遮擋,顯示在浮動(dòng)元素的下面,both
不會(huì)被左右兩邊的浮動(dòng)元素遮擋,顯示在浮動(dòng)元素的下面。
<head> <style> .wrap{ width: 300px; border: 1px solid #000; } .box{ width: 100px; height: 100px; background-color: pink; float: left; } .test{ clear: both; } </style> </head> <body> <div class="wrap clearFix"> <p class="box"></p> <p class="test"></p> </div> </body>
(5)萬能解決法
最終的解決方法是通過給父元素設(shè)置偽元素添加clear
屬性來解決浮動(dòng)帶來的問題。
因?yàn)槲覀冃枰诟冈睾竺嬖黾右粋€(gè)元素,用于設(shè)置清除浮動(dòng),所以使用::after
。該偽元素是不需要任何其他內(nèi)容的,但是content
是必須添加的。又因?yàn)?code>clear只對(duì)塊元素生效,而偽元素默認(rèn)添加的是行內(nèi)元素,所以必須通過display:block
修改元素的類型。
<head> <style> p{ width: 100px; height: 100px; backgroud-color: pink; float: left; } .clearFix{ /* 用于兼容低版本ie 開啟haslayout */ *zoom: 1; } .clearFix::after{ content: ""; display: block; clear: both; } </style> </head> <body> <div class="clearFix"> <p><p> <div> </body>
到此這篇關(guān)于CSS實(shí)現(xiàn)浮動(dòng)效果的文章就介紹到這了,更多相關(guān)css 浮動(dòng)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!
相關(guān)文章
- CSS Grid 是一種二維布局系統(tǒng),可以同時(shí)控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋2025-04-16
CSS Padding 和 Margin 區(qū)別全解析
CSS 中的 padding 和 margin 是兩個(gè)非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實(shí)際項(xiàng)目中使用它們2025-04-07- will-change 是一個(gè) CSS 屬性,用于告訴瀏覽器某個(gè)元素在未來可能會(huì)發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧2025-04-07
- 本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-04-07
- 在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實(shí)現(xiàn)復(fù)雜交互和動(dòng)態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級(jí),本文將2025-04-07
css中的 vertical-align與line-height作用詳解
文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧2025-03-26淺析CSS 中z - index屬性的作用及在什么情況下會(huì)失效
z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用2025-03-21- 文章詳細(xì)介紹了CSS中的打印媒體查詢@mediaprint包括基本語法、常見使用場景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁控制、調(diào)整邊距和背景等2025-03-18
CSS模擬 html 的 title 屬性(鼠標(biāo)懸浮顯示提示文字效果)
本文介紹了如何使用CSS模擬HTML的title屬性,通過鼠標(biāo)懸浮顯示提示文字效果,通過設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實(shí)現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起2025-03-10前端 CSS 動(dòng)態(tài)設(shè)置樣式::class、:style 等技巧(推薦)
本文介紹了Vue.js中動(dòng)態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對(duì)象語法和數(shù)組語法,通過對(duì)象語法,可以根據(jù)條件動(dòng)態(tài)切換類名或樣式;通過數(shù)組語法,可以同時(shí)綁定多個(gè)類名或樣式,此外2025-02-26