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

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

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

一、浮動(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ì)。

  • floatnone無浮動(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ì)塊元素生效。

clearnone默認(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 布局示例詳解

    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
  • CSS will-change 屬性示例詳解

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

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

    在前端開發(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
  • 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`的樣式,實(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

最新評(píng)論