首頁  >  文章  >  web前端  >  利用CSS定位背景圖片的常用方法總結

利用CSS定位背景圖片的常用方法總結

巴扎黑
巴扎黑原創
2017-03-30 14:39:091632瀏覽

前言

大家在網路上最常見的一個方案就是在父元素中relative,然後子元素absolute。這個方案當然好,不過帶來的一個缺點就是會改變元素的層級關係,如果在多個地方使用,這樣的層疊嵌套的關係會十分混亂。本文先暫時拋棄那種方案,跟大家分享幾種CSS背景圖片定位的方案。

1.無依賴的absolute定位

在網路上,對absolute存在這樣一個誤解,認為絕對定位absolute的使用必須要設定父元素相對定位relative 。這樣的理解不能認為是錯的,只能說對定義沒有完全認識。在W3C文件中是這樣定義absolute的:

產生絕對定位的元素,相對於static定位以外的第一個父元素進行定位。元素的位置透過'left' , 'right' , 'bottom' , 'top' 屬性進行規定。

對這句話的理解應該如下(L : left,R:right,B:bottom,T:top)

a:當給一個元素設定position:absolute之後,如果父元素沒有設定position:relative,則該元素是透過LRBT依據可視視窗區域的左上角進行定位;如果父元素設定了position:relative,則該元素是透過LRBT依據父元素容器的左上角進行定位。

b:在產生絕對定位的元素時,不管父元素是否設定了position:relative,使用margin-top , margin-left , margin-right , margin-bottom其中的兩個非相反方向進行定位,其效果會像相對定位relative一樣,根據自身位置進行定位。但使用margin定位與relative唯一的差別就是,absolute脫離文檔流,原來的物理空間已經消失,而relative沒有脫離文檔流,原來的物理空間依然佔據。

所以,可以使用無依賴relative的absolute來定位,定位方法是使用margin,而不能使用LRBT。

程式碼如下:

<p class="keith">
        <p class="main"></p>
<p>        </p>
    </p>
.keith {
  margin: 2em;
  width: 5em;
  height: 5em;
  background: lightgreen;
}</p>
<p>.keith .main {
  position: absolute;
  background: url("../images/my-icons/Loginicon.png") scroll no-repeat 0 0;
  width: 21px;
  height: 21px;
  margin-left: calc(5em - 25px);
  margin-top: calc(5em - 25px);
}



#上面程式碼中,使用margin-left , margin-top 與 position:absolute來定位圖片。使用了CSS3中的calc()來計算需要定位的值。

範例圖片如下:

利用CSS定位背景圖片的常用方法總結

2.background-position擴充語法

在CSS3背景與邊框中,background-position屬性已經擴展,它允許我們指定背景圖片距離任意角的偏移量,只要我們在偏移量前面指定關鍵字即可。

程式碼如下:

<p class="keith"></p>
.keith{
    margin:2em;
    width:5em;
    height:5em;
    background:lightgreen url(&#39;../images/my-icons/Loginicon.png&#39;) scroll no-repeat ;
    background-position:right 5px bottom 5px;
};



#上面程式碼中,使用background-position擴充語法即可實現距離右下角5px距離的定位。

3.background-origin定位

background-origin是CSS3新增的屬性,主要用來決定background-position屬性的參考原點,也就是決定背景圖片定位的起點。在預設情況下,背景圖片的background-position屬性總是以元素左上角為座標原定對背景圖片進行背景定位。

background-origin有三個屬性值content-box , padding-box(預設值) , border-box 。

看看如何使用這個屬性來對背景圖片進行右下角5px的定位,程式碼如下。

<p class="keith"></p>
.keith {
  margin: 2em;
  width: 5em;
  height: 5em;
  padding: .5em;
  background: lightgreen url("../images/my-icons/Loginicon.png") scroll no-repeat;
  background-position: right bottom;
  -moz-background-origin: content;
  -o-background-origin: content-box;
  -webkit-background-origin: content;
  background-origin: content-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}



上面程式碼中,為盒子設定了padding值。使用box-sizing屬性來調整p在瀏覽器下的盒子模型為IE盒模型,border-box的意思是總寬度=content area + padding + border 。這裡為background-origin屬性設定了content-box,可能大家會不太懂,為什麼不是padding-box。看一個火狐下的截圖。

利用CSS定位背景圖片的常用方法總結

利用CSS定位背景圖片的常用方法總結

在上面圖片中,黃色區域的是margin,紫色區域的是padding,淺藍色區域的是content-area。如果為元素設定了padding-box,那麼此時圖片會定位在右下角,與右下角沒有任何空間。所以此時要使用content-box來定位。最終的效果如下。

利用CSS定位背景圖片的常用方法總結

4.calc()定位

#如果我們希望透過內容來撐開容器的寬度和高度時,而不去固定高度和寬度時,這時需要使用calc屬性+background-position屬性結合使用,來定位圖片。因為這時候並不知道容器的高度和寬度,只能有100%來計算。

<p class="keith">
        这是一段文字,用于撑开容器。
</p>
.keith{
    margin:2em;
    padding:2em;
    display:inline-block;
    background:lightgreen url(&#39;../images/my-icons/Loginicon.png&#39;) scroll no-repeat;
    background-position:calc(100% - 5px) calc(100% - 5px);
}</p>
<p>



範例圖片如下:



利用CSS定位背景圖片的常用方法總結


以上是利用CSS定位背景圖片的常用方法總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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