CSS進階之布局模型執行個體詳解

來源:互聯網
上載者:User
CSS中含有三種布局模型 流動模型Flow 浮動模型Float 層模型Layer

流動模型

網頁預設的布局模型 特點有兩個

1.塊狀元素都會在所處的包含元素內自上而下按順序垂直延伸分布,因為在預設狀態下,塊狀元素的寬度都為100%。實際上,塊狀元素都會以行的形式佔據位置。

<style type="text/css">    h1,p,div{        border:1px solid red;    }</style>

2.在流動模型下,內嵌元素都會在所處的包含元素內從左至右水平分布顯示。

<a href="http://>www.baidu.com</a><span>hello</span><em>shit</em><strong>world</strong>

www.baidu.com hello shit world 會水平顯示在同一行中。

2.浮動模型 FLoat

任何元素在預設情況下是不能浮動的,但可以用 CSS 定義為浮動,如 div、p、table、img 等元素都可以被定義為浮動 例如讓下面兩個div元素並排顯示在同一行

div{    border:1px solid red;    width:200px;    height:200px;    float:left;//從左向右排列}<div>hello</div><div>world</div>

3.層模型 Layer

能夠實現對於html元素的精準定位(用的不是特別多,但是局部使用層模型可以實現一些效果)

層模型有三種:

絕對位置:position:absolute

將元素從文檔流中拖出來,然後使用left、right、top、bottom屬性相對於其最接近的一個具有定位屬性的父包含塊進行絕對位置。如果不存在這樣的包含塊,則相對於body元素,即相對於瀏覽器視窗。

將div元素相對於瀏覽器視窗向右移動100px 向下移動200px

div{    position:absolute;    width:100px;    height:100px;    border:1px solid red;    left:100px;    top:200px;}

相對定為:position:relative

相對於以前的位置移動,移動的方向和幅度由left、right、top、bottom屬性確定,位移前的位置保留不動(eh1顯示在的位置,這一點尤其要進行注意)。

   .div1{    position:relative;    width:200px;    height:200px;    border:1px solid red;    left:200px;    top:200px;}<span>hello world><div class="div1">position:relative</div><span>eh1<span>

固定定位:position:fixed

相對移動的座標是視圖(螢幕內的網頁視窗)本身。由於視圖本身是固定的,它不會隨瀏覽器視窗的捲軸滾動而變化,除非你在螢幕中行動瀏覽器視窗的螢幕位置,或改變瀏覽器視窗的顯示大小,因此固定定位的元素會始終位於瀏覽器視窗內視圖的某個位置

#div2{    position:fixed;    bottom:100px;    right:100px;    width:200px;    height:200px;    border:1px solid red;}<div id="div2">position:fixed</div>

這樣無論瀏覽器中有多少內容,div始終處於視窗的右下角。

position:absolute 和position:relative的組合使用

由上面知道position:absolute是相對於瀏覽器進行定位的,可以通過position:relative實現position:absolute相對於其他的元素定位 但是必須滿足以下幾點:

1.被參照元素必須是定位元素的父元素

2.被參照元素設定為position:relative

3.定位元素設定為position:absolute

#div1{ border:1px solid red; width:200px; height:200px; position:relative;}#div2{ border:1px solid red; width:50px; height:50px; left:20px; top:20px; position:absolute;}<div id="div1">    <div id="div2">hello</div></div>

這樣就實現了div2相對於div1來定位了。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.