欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

CSS實現(xiàn)浮動效果

  發(fā)布時間:2024-04-27 15:48:19   作者:長傅   我要評論
最近遇到比較頭疼的事情,就是我的織夢程序制作的一個沙發(fā)類型的淘寶客網(wǎng)站經(jīng)常被掛黑鏈,上一次是7月份中旬,這次是8月底,好像這些黑客的工作習(xí)慣都是一個月一次

一、浮動

早期用于實現(xiàn)文字環(huán)繞圖片(環(huán)繞布局),現(xiàn)在用于讓元素并列布局(塊元素并排)。浮動元素會脫離文檔流,后邊的元素會把空出來的位置補上去。但是又因為浮動元素的層級高,所以會將未浮動的元素進(jìn)行覆蓋,但是文字不會。

  • floatnone無浮動,left左浮動,right右浮動。

1、css布局的三種機(jī)制

  • 標(biāo)準(zhǔn)文檔流,也叫標(biāo)準(zhǔn)流,普通流。主要實現(xiàn)上下布局,也就是頁面布局的默認(rèn)效果。
  • 浮動流,通過float實現(xiàn)并列顯示的布局。
  • 定位流,通過position實現(xiàn)元素的層疊顯示的布局。

2、浮動布局的特點

(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)浮動的元素會因為當(dāng)前容器的橫向距離不足以擺放的時候,而發(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)實現(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è)置寬高的時候,寬高會根據(jù)內(nèi)容自動撐開,而不是顯示獨占一行。

二、浮動對元素的影響及解決方法

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。因為父元素在沒設(shè)置高度時,不知道在哪個位置隱藏。該方法前提是父元素不能設(shè)置定高,相對推薦。

        .wrap{
            width: 300px;
            border: 1px solid #000;
            overflow: hidden;
        }
  • 給父元素添加浮動。但是浮動會脫離文檔流,對頁面的影響較大,而且還可能會引起新的塌陷問題。不推薦。
  • 給父元素添加絕對定位或固定定位。但也會脫離文檔流,造成新的頁面問題,不推薦。

(3)改變父元素的類型為inline-block

因為浮動只對塊元素有效。但是行內(nèi)塊元素會因為換行符有留白。而且margin:0 auto不能居中顯示,這時想要居中可以給父元素設(shè)置text-align:center。

(4)清除浮動clear(額外標(biāo)簽法)

在浮動元素的后面添加一個空白標(biāo)簽,給它設(shè)置清除浮動屬性,從而撐開父元素的高度。
清除浮動是設(shè)置給被影響的元素,不是設(shè)置給浮動的元素。
該屬性只對塊元素生效。

clearnone默認(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屬性來解決浮動帶來的問題。
因為我們需要在父元素后面增加一個元素,用于設(shè)置清除浮動,所以使用::after。該偽元素是不需要任何其他內(nèi)容的,但是content是必須添加的。又因為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實現(xiàn)浮動效果的文章就介紹到這了,更多相關(guān)css 浮動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

相關(guān)文章

  • 前端CSS Grid 布局示例詳解

    CSS Grid 是一種二維布局系統(tǒng),可以同時控制行和列,相比 Flex(一維布局),更適合用在整體頁面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋
    2025-04-16
  • CSS Padding 和 Margin 區(qū)別全解析

    CSS 中的 padding 和 margin 是兩個非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實際項目中使用它們
    2025-04-07
  • CSS will-change 屬性示例詳解

    will-change 是一個 CSS 屬性,用于告訴瀏覽器某個元素在未來可能會發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧
    2025-04-07
  • CSS去除a標(biāo)簽的下劃線的幾種方法

    本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2025-04-07
  • 前端高級CSS用法示例詳解

    在前端開發(fā)中,CSS(層疊樣式表)不僅是用來控制網(wǎng)頁的外觀和布局,更是實現(xiàn)復(fù)雜交互和動態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級,本文將
    2025-04-07
  • css中的 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
  • CSS @media print 使用詳解

    文章詳細(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`的樣式,實現(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ù)組語法,可以同時綁定多個類名或樣式,此外
    2025-02-26

最新評論