利用CSS定位背景圖片 background-position

又如:
這些小圖片就是整圖分割后的各個部分,把各個部分放在一張圖片上,而不是是分別存儲成單獨的圖片,其目的我們都知道,就是減少http請求次數,節(jié)省時間和帶寬。
那么怎么來實現一張圖片在不同的地方只顯示其中的一部分呢,這就用到了我們今天要說的背景圖片的定位問題。這個問題相信很多人都郁悶過,也經常有朋友問我,所以今天就系統(tǒng)的說一下:
我們知道在用圖片作為背景的時候,css要這樣寫,以div容器舉例子,也可以是body、td、p等的背景,道理一樣。
代碼: div{ background:#FFF url(image) no-repeat fixed x y;} |
這里的background的屬性值依次為:
#FFF 背景色:(顏色值,背景圖片沒有覆蓋的地方,或者沒有背景圖片時表現的背景色)
image 背景圖片:(這里是圖片的地址)
no-repeat 是否重復:(圖片小于容器的大小時,默認會重復排列圖片以填滿容器,no-repeat表示不重復,只有這個時候后面的定位坐標才有用。)
fixed 背景是否隨容器滾動:(有兩個可選值,scroll滾動,fixed不滾動,默認是scroll)
x y 背景圖像的定位:(注意,只有在no-repeat下定位才有意義。這個就是今天要講的重點)
背景圖像定位中我們要明確的幾點:
1、兩個值前面一個是橫向的定位,我們稱為x軸方向定位。后面一個值是縱向的定位,我們稱為y軸方向定位。如果只有一個值,那默認的就是x軸方向,這時y軸方向就默認的是上下居中對齊,也就是center。
2、坐標軸的原點就是對應容器的左頂點。
3、這個坐標的y軸箭頭朝下,也就是右下方(容器內部)x y的值才都為正。
4、x y值分別表示背景圖片的左頂點相對于坐標原點(也就是容器的左頂點)的值。
5、x y的值可以用百分比或者px來表示。
6、x y也可以用“left、right、top、bottom、center”這五個對齊方式來表示,但注意:用“left、right、top、bottom、center”來表示的時候,應用的是對齊規(guī)則,而不是坐標規(guī)則。x為left是表示圖片的左邊和容器的左邊對齊,為right的時候表示圖片的右邊和容器的右邊對其,y為top的時候表示圖片的頂部和容器的頂部對齊,為bottom時表示圖片的底部和容器的底部對齊,x y等于center的時候表示居中對齊。
7、x y用百分比或者px表示的時候,其值可以為負數。我們應用坐標規(guī)則就很容易理解負數表示的意義,x為負數時候表示圖片左頂點在容器左頂點的左側,y為負數時表示圖片的左頂點在容器的左定點的上方。也就是向左和向上超出容器的范圍。
下面我用幾個圖示來說明一下幾種情況,藍色塊表示圖片,虛線框表示容器(可以div,td,或者直接就是body),注意只有背景圖片在容器內我們才能看見,我用白色表示可見部分,而且超出容器范圍的是看不見的,我用灰色表示。容器的左定點的坐標就是(0,0)。
第一張,背景圖片和容的左上對齊,0px 0px 也可以寫成left top
第二張,背景圖在容器中間,定點坐標為正值
第三張,背景圖部分在容器左上,定點坐標為負值
---------------------------------------------------------------------------
到此我們可能就明白了如何用background里的定位值來準確定位一個背景圖片,返回去我們看一下開始的時候介紹的兩個圖片,我們就是可以用:背景定位和容器內才可見這兩個性質來隨意的調用整張圖片的某一部分。
但是我們?yōu)榱苏{用方便,在排列這些小圖片的時候要講究一點規(guī)則,比如:小圖之間的距離通常是調用小圖的容器的大小,或者距離更大一點,這樣就可以避免在容器內顯示出我們不愿意顯示的圖片!
補充一點,如果定位用的是百分比話,算法比較特殊。我舉個例子:
代碼: background:#FFF url(image) no-repeat fixed 50% -30%; |
這個時候圖片應該在容器的什么位置呢,算法公式如下:
圖片左頂點距容器左頂點的坐標位置為
x:(容器的寬度-圖片的寬度)x50%
y:(容器的高度-圖片的高度)x(-30%)
得到的結果應用坐標法則,差值如果為負數,百分比為正那么運算結果是負值。如果差值為負數,百分比也為負數,那么運算結果就是正數??偠灾褪沁@里的運算符合運算法則。把運算的結果帶入坐標法則就能得到圖片的位置。
比如:容器是width:600px;height:600px;而圖片是width:200px;height:200px;
我們用上面的樣式,可以得到圖片位置為:
x:(600px-200px)*50%
y:(600px-200px)*(-30%)
如下圖:
相關文章
CSS規(guī)則的結構和Grouping、class和id-CSS教程-網頁制作-網頁教學網
2.1 規(guī)則的結構 <rules>::=<selector> <左括號><declarations><右括號> <declarations>::= <declaration>{<SE2008-10-17- 下面小編就為大家?guī)硪黄猚ss background 背景圖的設置方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-30
CSS的background屬性及CSS3的背景圖片設置總結
這篇文章主要介紹了CSS的background屬性及CSS3的背景圖片設置總結,背景圖片的顯示區(qū)域和定位是非常值得注意的地方,需要的朋友可以參考下2016-06-13- 固定背景圖片的通常方法就是把background-attachment設成fix,進一步的話自然則是用background-position,下面來詳解使用CSS固定頁面背景圖片及位置的方法:2016-05-17
- 在chrome,FF里調試完后,忽然想起ie來,放到Ie里其它還好了,但是有個背景圖片顯示不出來,具體的寫法如下,有類似情況的朋友可以參考下2013-11-25
- 設置背景圖的方法一般是使用css的background:url來實現的,下面有個示例,大家可以參考下2013-10-14
學習CSS的背景圖像屬性background-CSS教程-網頁制作-網頁教學網
CSS的背景屬性“background”提供了眾多屬性值,如顏色、圖像、定位等,為網頁背景圖像的定義提供了極大的便利??纯碽ackground提供的屬性值: background2008-10-17通過css使用background-color為背景圖添加遮罩效果的兩種方法
這篇文章主要介紹了通過css使用background-color為背景圖添加遮罩效果的兩種方法,需要的朋友可以參考下2018-07-12