CSS實(shí)現(xiàn)浮動效果
一、浮動
早期用于實(shí)現(xiàn)文字環(huán)繞圖片(環(huán)繞布局),現(xiàn)在用于讓元素并列布局(塊元素并排)。浮動元素會脫離文檔流,后邊的元素會把空出來的位置補(bǔ)上去。但是又因?yàn)楦釉氐膶蛹壐?,所以會將未浮動的元素進(jìn)行覆蓋,但是文字不會。
float:none無浮動,left左浮動,right右浮動。
1、css布局的三種機(jī)制
- 標(biāo)準(zhǔn)文檔流,也叫標(biāo)準(zhǔn)流,普通流。主要實(shí)現(xiàn)上下布局,也就是頁面布局的默認(rèn)效果。
- 浮動流,通過
float實(shí)現(xiàn)并列顯示的布局。 - 定位流,通過
position實(shí)現(xiàn)元素的層疊顯示的布局。
2、浮動布局的特點(diǎn)
(1)浮動元素會以頂對齊,且沒有縫隙緊挨著的方式進(jìn)行顯示。
(2)如果元素集體右浮動,顯示的順序會發(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)浮動的元素會因?yàn)楫?dāng)前容器的橫向距離不足以擺放的時(shí)候,而發(fā)生換行。
如果元素的高度都是相等的,那就是另起一行的效果;如果元素的高度呈階梯狀,后續(xù)的元素在頂對齊放不下的情況下,會向下落到第一個障礙處停下來,且其之后的元素會排在它的后面。
<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)浮動元素脫離文檔流,提升元素的層級。
<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>
綠色盒子添加浮動后,脫離了文檔流,浮在了藍(lán)色盒子的上面。
(5)實(shí)現(xiàn)并列布局的元素都要增加浮動屬性。
(6)浮動的元素設(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)我們添加浮動屬性之后,margin:0 auto居中失效。
(7)浮動的元素會轉(zhuǎn)變成塊元素。
<head>
<style>
span{
background-color: pink;
padding: 30px;
float: left;
}
</style>
</head>
<body>
<span></span>
</body>
這里可以看出原本的行內(nèi)元素在添加浮動后,可以設(shè)置padding值,同樣也可以設(shè)置寬高。沒設(shè)置寬高的時(shí)候,寬高會根據(jù)內(nèi)容自動撐開,而不是顯示獨(dú)占一行。
二、浮動對元素的影響及解決方法
1、浮動對元素的影響
- 子元素浮動會引起父元素的高度塌陷。
- 塊元素浮動之后,默認(rèn)寬度不會顯示成父元素100%的效果了,而是靠內(nèi)容撐開,但是設(shè)置寬高依然有效。
- 行內(nèi)元素、行內(nèi)塊元素增加浮動會被隱性轉(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(塊級格式化上下文)
給父元素添加overfloat:hidden。因?yàn)楦冈卦跊]設(shè)置高度時(shí),不知道在哪個位置隱藏。該方法前提是父元素不能設(shè)置定高,相對推薦。
.wrap{
width: 300px;
border: 1px solid #000;
overflow: hidden;
}- 給父元素添加浮動。但是浮動會脫離文檔流,對頁面的影響較大,而且還可能會引起新的塌陷問題。不推薦。
- 給父元素添加絕對定位或固定定位。但也會脫離文檔流,造成新的頁面問題,不推薦。
(3)改變父元素的類型為inline-block
因?yàn)楦又粚K元素有效。但是行內(nèi)塊元素會因?yàn)閾Q行符有留白。而且margin:0 auto不能居中顯示,這時(shí)想要居中可以給父元素設(shè)置text-align:center。
(4)清除浮動clear(額外標(biāo)簽法)
在浮動元素的后面添加一個空白標(biāo)簽,給它設(shè)置清除浮動屬性,從而撐開父元素的高度。
清除浮動是設(shè)置給被影響的元素,不是設(shè)置給浮動的元素。
該屬性只對塊元素生效。
clear:none默認(rèn)值,會被浮動元素遮擋;left不會被向左浮動的元素遮擋,顯示在浮動元素的下面;right不會被向右浮動的元素遮擋,顯示在浮動元素的下面,both不會被左右兩邊的浮動元素遮擋,顯示在浮動元素的下面。
<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屬性來解決浮動帶來的問題。
因?yàn)槲覀冃枰诟冈睾竺嬖黾右粋€元素,用于設(shè)置清除浮動,所以使用::after。該偽元素是不需要任何其他內(nèi)容的,但是content是必須添加的。又因?yàn)?code>clear只對塊元素生效,而偽元素默認(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)浮動效果的文章就介紹到這了,更多相關(guān)css 浮動內(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 是兩個非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實(shí)際項(xiàng)目中使用它們2025-04-07- will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧2025-04-07
- 本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧2025-04-07
在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實(shí)現(xiàn)復(fù)雜交互和動態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將2025-04-07css中的 vertical-align與line-height作用詳解
文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場景、常見問題及解決方案,感興趣的朋友跟隨小編一起看看吧2025-03-26淺析CSS 中z - index屬性的作用及在什么情況下會失效
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 動態(tài)設(shè)置樣式::class、:style 等技巧(推薦)
本文介紹了Vue.js中動態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對象語法和數(shù)組語法,通過對象語法,可以根據(jù)條件動態(tài)切換類名或樣式;通過數(shù)組語法,可以同時(shí)綁定多個類名或樣式,此外2025-02-26




