CSS

CSS3布局模型

字號+ 編輯: Snake 修訂: H波 來源: 慕课网 2023-09-08 我要說兩句(0)

清楚了CSS3盒模型的基本概念、盒模型類型,可以深入探討網頁布局的基本模型了。布局模型與盒模型一樣都是 CSS3 最基本、 最核心的概念。 但布局模型是建立在盒模型基礎之上,又不同於我們常說的 CSS3 布局樣式或 CSS3 布局模板。如果說布局模型是本,那麽 CSS3 布局模板就是末了,是外在的表現形式。CSS3包含3種基本的布局模型,用英文概括爲:Flow、Layer 和 Float。

13-1 css布局模型

清楚了CSS3盒模型的基本概念、盒模型類型,可以深入探討網頁布局的基本模型了。布局模型與盒模型一樣都是 CSS3 最基本、 最核心的概念。 但布局模型是建立在盒模型基礎之上,又不同於我們常說的 CSS3 布局樣式或 CSS3 布局模板。如果說布局模型是本,那麽 CSS3 布局模板就是末了,是外在的表現形式。

CSS3包含3種基本的布局模型,用英文概括爲:Flow、Layer 和 Float。

在網頁中,元素有三種布局模型:

1、流動模型(Flow)

2、浮動模型 (Float)

3、層模型(Layer)

13-2 流動模型(一)

流動(Flow)是默認的網頁布局模式。網頁在默認狀態下的HTML網頁元素都是根據流動模型來分布網頁内容的。

流動布局模型具有2個比較典型的特征:

第一點,塊狀元素都會在所處的包含元素内自上而下按順序垂直延伸分布,因爲在默認狀態下,塊狀元素的寬度都爲100%。實際上,塊狀元素都會以行的形式佔據位置。

如圖:三個塊狀元素標簽(div,h1,p)寬度顯示爲100%。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>流動模式下的塊狀元素</title>
    <style type="text/css">
    #box1 {
        width: 300px;
        height: 100px;
    }
    div,
    h1,
    p {
        border: 1px solid red;
    }
    </style>
</head>
<body>
    <div id="box2">box2</div>
    <!--塊狀元素,由於沒有設置寬度,寬度默認顯示爲100%-->
    <h1>標題</h1>
    <!--塊狀元素,由於沒有設置寬度,寬度默認顯示爲100%-->
    <p>文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段文本段。</p>
    <!--塊狀元素,由於沒有設置寬度,寬度默認顯示爲100%-->
    <div id="box1">box1</div>
    <!--塊狀元素,由於設置了width:300px,寬度顯示爲300px-->
</body>
</html>

1.png

第二點,在流動模型下,内聯元素都會在所處的包含元素内從左到右水平分布顯示。

(内聯元素不像塊狀元素獨佔一行)

如圖:内聯元素標簽a、span、em、strong都是内聯元素。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>流動模式下的内聯元素</title>
    <style type="text/css">
    </style>
</head>
<body>
    <a href="http://www.imooc.com">www.wkwkk.com</a><span>強調</span><em>重點</em>
    <strong>強調</strong>
</body>
</html>

執行結果:

www.wkwkk.com強調重點 強調

13-3 浮動模型

塊狀元素都是獨佔一行,想讓兩個塊狀元素並排顯示,設置元素浮動可以實現。

任何元素在默認情況下是不能浮動的,但可以 CSS定義爲浮動,如div、p、table、img等元素都可以被定義爲浮動。

實現兩個div元素一行顯示。

div{
  width:200px;
  height:200px;
  border:2px red solid;
  float:left;
}
<div id="div1"></div>
<div id="div2"></div>

 圖片18.jpg

可以同時設置兩個元素右浮動也可以實現一行顯示。

div{
  width:200px;
  height:200px;
  border:2px red solid;
  float:right;
}

圖片19.jpg 

設置兩個元素一左一右顯示:

div{
  width:200px;
  height:200px;
  border:2px red solid;
}
#div1{float:left;}
#div2{float:right;}

 圖片20.jpg

13-4 層模型

層布局模型就像是圖像軟體PhotoShop中非常流行的圖層編輯功能一樣,每個圖層能夠精確定位操作,但在網頁設計領域,由於網頁大小的活動性,層布局沒能受到熱捧。但是在網頁上局部使用層布局還是有其方便之處的。下面我們來學習一下html中的層布局。

如何讓html元素在網頁中精確定位,就像圖像軟體PhotoShop中的圖層一樣可以對每個圖層能夠精確定位操作。CSS定義了一組定位(positioning)屬性來支持層布局模型。

層模型有三種形式:

1、絕對定位(position: absolute)

2、相對定位(position: relative)

3、固定定位(position: fixed)

13-5 層模型之絕對定位

如果想爲元素設置層模型中的絕對定位,需要設置position:absolute(表示絕對定位),這條語句的作用將元素從文档流中拖出來,然後使用left、right、top、bottom屬性相對於其最接近的一個具有定位屬性的父包含塊進行絕對定位。如果不存在這樣的包含塊,則相對於body元素,即相對於瀏覽器窗口。

下面代碼可以實現div元素相對於瀏覽器窗口向右移動100px,向下移動50px。

div{
  width:200px;
  height:200px;
  border:2px red solid;
  position:absolute;
  left:100px;
  top:50px;
}
<div id="div1"></div>

效果如下:

 圖片21.jpg

13-6 層模型之相對定位

爲元素設置層模型中的相對定位,需要設置position:relative(表示相對定位),它通過left、right、top、bottom屬性確定元素在正常文档流中的偏移位置。相對定位完成的過程是首先按static(float)方式生成一個元素(並且元素像層一樣浮動了起來),然後相對於以前的位置移動,移動的方向和幅度由left、right、top、bottom屬性確定,偏移前的位置保留不動。

如下代碼實現相對於以前位置向下移動50px,向右移動100px;

#div1{
  width:200px;
  height:200px;
  border:2px red solid;
  position:relative;
  left:100px;
  top:50px;
}
<div id="div1"></div>

效果圖:

 圖片22.jpg

什麽叫做“偏移前的位置保留不動”呢?

在右側代碼編輯器的19行div標簽的後面加入一個span標簽,並在span標簽中寫入一些文字。如下代碼:

<body>
   <div id="div1"></div><span>偏移前的位置還保留不動,覆蓋不了前面的div沒有偏移前的位置</span>
</body>

效果圖:

 圖片23.jpg

從效果圖中可以明顯的看出,雖然div元素相對於以前的位置産生了偏移,但是div元素以前的位置還是保留著,所以後面的span元素是顯示在了div元素以前位置的後面。

13-7 層模型之固定定位

fixed:表示固定定位,與absolute定位類型類似,但它的相對移動的坐標是視圖(屏幕内的網頁窗口)本身。由於視圖本身是固定的,它不會隨瀏覽器窗口的滾動條滾動而變化,除非你在屏幕中移動瀏覽器窗口的屏幕位置,或改變瀏覽器窗口的顯示大小,因此固定定位的元素會始終位於瀏覽器窗口内視圖的某個位置,不會受文档流動影響,這與background-attachment:fixed;屬性功能相同。以下代碼可以實現相對於瀏覽器視圖向右移動100px,向下移動50px。並且拖動滾動條時位置固定不變。

#div1{
  width:200px;
  height:200px;
  border:2px red solid;
  position:fixed;
  left:100px;
  top:50px;
}
<p>文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文本文。</p>
....

13-8 Relative與Absolute組合使用

學習了絕對定位的方法:使用position:absolute可以實現被設置元素相對於瀏覽器(body)設置定位以後,可不可以相對於其它元素進行定位呢?使用position:relative來幫忙,但是必須遵守下面槼範:

1、參照定位的元素必須是相對定位元素的前輩元素:

<div id="box1"><!--參照定位的元素-->
    <div id="box2">相對參照元素進行定位</div><!--相對定位元素-->
</div>

從上面代碼可以看出box1是box2的父元素(父元素當然也是前輩元素了)。

2、參照定位的元素必須加入position:relative;

#box1{
  width:200px;
  height:200px;
  position:relative;
}

3、定位元素加入position:absolute,便可以使用top、bottom、left、right來進行偏移定位了。

#box2{
  position:absolute;
  top:20px;
  left:30px;
}

這樣box2就可以相對於父元素box1定位了(這裡注意參照物就可以不是瀏覽器了,而可以自由設置了)。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>相對參照元素進行定位</title>
    <style type="text/css">
    div {
        border: 2px red solid;
    }
    #box1 {
        width: 200px;
        height: 200px;
        position: relative;
    }
    #box2 {
        position: absolute;
        top: 20px;
        left: 30px;
    }
    /*下面是任務部分*/
    #box3 {
        width: 200px;
        height: 200px;
        position:relative;
    }
    #box4 {
        width: 99%;
        position:absolute;
        bottom:0;
    }
    </style>
</head>
<body>
    <div id="box1">
        <div id="box2">相對參照元素進行定位</div>
    </div>
    <h1>下面是任務部分</h1>
    <div id="box3">
        <img src="http://img.mukewang.com/541a7d8a00018cf102000200.jpg">
        <div id="box4">當我還是三年級的學生時是一個害羞的小女生。</div>
    </div>
</body>
</html>

2.png

閲完此文,您的感想如何?
  • 有用

    0

  • 沒用

    0

  • 開心

    0

  • 憤怒

    0

  • 可憐

    0

1.如文章侵犯了您的版權,請發郵件通知本站,該文章將在24小時内刪除;
2.本站標注原創的文章,轉發時煩請注明來源;
3.交流群: 2702237 13835667

相關課文
  • 多個高度相同, 屬性inline-block的div,有的div沒有内容而有的div有内容,有内容的會下沉?

  • 讓整個網頁全局變成黑白色調的css代碼

  • CSS生成内容

  • CSS3外輪廓屬性

我要說說
網上賓友點評