首頁 >web前端 >css教學 >CSS浮動float、定位position

CSS浮動float、定位position

高洛峰
高洛峰原創
2017-02-27 09:33:121526瀏覽

一 . 浮動float

I . 定義及規則

float預設為none,對應標準流的情況。當float : left;時,元素就會向其父元素的左側靠緊,脫離標準流,同時寬度不再伸展至充滿父容器,而是根據自身內容來確定。

II .示範規則

準備程式碼

<html xmlns="http://www.w3.org/1999/xhtml">  
<head>  
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
    <title></title>  
    <style>  
        body   
        {   
            margin: 0;   
            padding: 0;   
        }   
  
        #father   
        {   
            background-color: cyan;   
  
            /*父级p 没有定位 造成子p的margin-top传递给父级*/   
            position: absolute;   
        }   
  
            #father *   
            {   
                margin: 10px;   
                padding: 10px;   
                border: 1px dashed red;   
            }   
  
        #son1   
        {   
        }   
  
        #son2   
        {   
        }   
  
        #son3   
        {   
        }   
    </style>  
</head>  
<body>  
    <p id="father">  
        <p id="son1">#son1</p>  
        <p id="son2">#son2</p>  
        <p id="son3">#son3-son3son3son3</p>  
        <p>  
        这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字这是文字   
        </p>  
    </p>  
</body>  
</html>

1、中間給#father加上position:absolute,是為了消除未定位父p的margin-top傳遞問題,相關內容如下

嵌套p中margin-top轉移問題的解決方法

##在這兩個瀏覽器中,有兩個巢狀關係的p,如果外層p的父元素padding值為0,那麼內層p的margin-top或margin-bottom的值會「轉移」給外層p。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
<html xmlns="http://www.w3.org/1999/xhtml">  
<head>  
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />  
<title>无标题文档</title>  
</head>  
  
<body>  
<p style="background-color:#FF0000;width:300px; height:100px">上部层</p>  
  
<p style="background-color:#009900; width:300px; height:300px;overflow:hidden "> <!--父层-->  
     <p style="margin:50px; background-color:#000000;width:200px; height:200px"">子层</p>  
</p>  
  
</body>  
</html>

原因:盒子沒有獲得haslayout  造成margin-top無效

 
解決方法:
1、在父層p加上:overflow:hidden;
2、把margin-top外邊距改成padding-top內邊距;
3、父元素產生邊距重疊的邊有不為0 的padding 或寬度不為0 且style 不為none 的border 。
    父層p加: padding-top: 1px;
4、讓父元素產生一個block formating context,以下屬性可實現
    * float: left/right
    * position: ab * float: left/right
    * position: absolsolute# #    * display: inline-block/table-cell(或其他table 類型)
    * overflow: hidden/auto
   父層p加:position: absolute;

CSS浮動float、定位position#2、1,2的float分別為left right時,有

CSS浮動float、定位position

可見1,2脫離標準流,標準流中的son3當他們不存在,於是son3代替原來son1的位置,而son1的左border、son2的右border與son3的左右border重合


3、當1,2,3全都float left時

CSS浮動float、定位position文字圍繞著float過的p

4、1,2左浮動,3右浮動,當窗口寬度減小時, 3會被擠下來

CSS浮動float、定位position當3左浮動,2右浮動的時候,顯示為

CSS浮動float、定位position當瀏覽器窗口寬度減少小時,猜猜誰會被擠下來,son2麼?

CSS浮動float、定位position

答案還是son3,規則為: 寫在html檔案中後面的會被擠下來,在html檔案中,son3在son2後面,因此總是son3先擠下來。


5、增加son1高度,son3擠下來時會卡在那裡

CSS浮動float、定位position#6、刪除盒子中的文字,3個子p全部左浮動

顯示為



CSS浮動float、定位position父p中的三個子p全部脫離標準流了,父p就縮成一條線了,可以用clear來修正

加一個margin-padding-border全為0,clear為both的空p,來撐大父p


III . clear清除浮动
如果前面有float:left的元素,他会影响下面元素,如上例中的p,在p元素中写clear : left即可消除前面左浮动元素对本元素的影响.同理clear:both是左右都清除.

二 . 定位position

position取值有static absolute relative fixed

1. static
这个是默认的,即标准流排下来,就是static定位方式.

2. fixed
在浏览器窗口中固定,什么论坛中的[回到顶部]这种按钮就是fixed做的
练习做个回到顶部玩玩

<p id="backToTop">   
    回到顶部   
</p>   
#backToTop   
{   
    width: 100px;   
    height: 50px;   
  
  
    background-color: red;   
    color: white;   
    cursor: pointer;   
    border-radius: 25px 0 0 25px;   
    padding-left: 20px;   
  
  
    text-align: center;   
    line-height: 50px;   
  
    position: fixed;   
    bottombottom: 80px;   
    rightright: 0;   
}

显示效果

CSS浮動float、定位position



3. relative相对定位

相对于自己的偏移,而且不脱离标准流,使用top/bottom left/right指定偏移量

4. absolute绝对定位

根据别的已定位元素进行定位,应用absolute规则的脱离标准流

1)、这个别的元素:
离它最近的已定位的祖先元素 或者 浏览器窗口,当找不到前面的祖先元素时,就以后者浏览器窗口来定位.
2)、已经定位 : 是指position已经设置,而且不是static...即position值不为static就是已经定位的元素,未设置position或设置为static认为它没有定位.
Trick

只设置 position : absolute,而不设置top/bottom/left/right值,那么元素会保持在原地,但是已经脱离标准流.

三 . display

display取值有inline block none

设置为none,即可将其隐藏,像inline-block等新添加的

以上就是本文的全部内容,希望对大家学习CSS教程有所帮助。

更多CSS浮動float、定位position相关文章请关注PHP中文网!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn