css3 background-image屬性執行個體詳解

來源:互聯網
上載者:User
這篇文章主要介紹了css3實現一個p設定多張背景圖片及background-image屬性,同時對於css3背景漸層也做了詳細的解釋,水平漸層,左上方漸層等等方式,需要的朋友可以參考下

引子

以前做網頁布局的時候,一個p只能設定一張背景圖片,設定多個背景的話,要用多個p嵌套才能實現,這樣相容性比較好。若您的網站要求相容瀏覽器低版本,建議用這種方法。css3的出現,解決了一個p只能設定一個背景的問題,使一個p可以設定多個背景圖片。background-image還可以設定線性漸層,等效果。

題外話

關於css3的background,功能很強大,有很多屬性,像background-size等等,這些屬性都可以寫一篇部落格來講述。關於css3background的其他屬性,後面會出部落格來單獨講述!

CSS3/CSS1 background-image 屬性

文法:


background-image:<bg-image> [ , <bg-image> ]*<bg-image> = none | <url> | <linear-gradient> | <radial-gradient> | <repeating-linear-gradient> | <repeating-radial-gradient>預設值:none

取值:


none:無背景圖。< url >:使用絕對或相對位址指定背景映像。< linear-gradient>:使用線性漸層建立背景映像。(CSS3)< radial-gradient>:使用徑向(放射性)漸層建立背景映像。(CSS3)< repeating-linear-gradient>:使用重複的線性漸層建立背景映像。(CSS3)< repeating-radial-gradient>:使用重複的徑向(放射性)漸層建立背景映像。(CSS3)

說明

設定或檢索對象的背景映像。
如果設定了background-image,同時也建議作者設定background-color用於當背景映像不可見時保持與文本一定的對比。
對應的指令碼特性為backgroundImage

相容性:

IE8及更早瀏覽器不支援CSS3 background-image,即不支援多背景和使用漸層作為背景映像。
IE9不支援CSS3新增參數值:< linear-gradient > | < radial-gradient > |< repeating-linear-gradient > | < repeating-radial-gradient >作為背景映像。
Opera11.50-11.51不支援CSS3新增參數值:< radial-gradient > |< repeating-radial-gradient >作為背景映像。

寫法:

css3設定多張背景圖片

css3設定多張背景圖片,可以如下寫:

background:url("haoroomsCSS1_s.jpg") 0 0 no-repeat,
url("haoroomsCSS2_s.jpg") 200px 0 no-repeat,
url("haorooms.jpg") 400px 201px no-repeat;
也可以這麼寫:

background-image:url("1.jpg"),url("2.jpg"),url("3.jpg");
background-repeat: no-repeat, no-repeat, no-repeat;
background-position: 0 0, 200px 0, 400px 201px;

css3背景漸層

標準寫法


background-image: linear-gradient(  [ <angle> | <side-or-corner> ,]? <color-stop> [, <color-stop>]+ );


上面這種CSS文法我們經常見到,可能有人看不懂具體的意思,其實上面的些符號含義與Regex有很多一致之處:

[]在正則中表示一個字元類,這裡,你可以理解為一個小單元。

|表示候選。也就是“或者”的意思,要麼前面的,要麼就後面的。

?為量詞,表示0個或1個,言外之意就是,你可以不指定方向,直接漸層色走起。例如:


background:linear-gradient(red, yellow);


就是從上往下的紅黃條紋效果。

+也是量詞,表示1個或者更多個。因此,終止顏色是不可缺少的。例如:linear-gradient(red)是醬油命,白板。

<>中的是關鍵字,主要是讓開發人員知道這裡應該放些什麼內容。

水平漸層


{background-image:linear-gradient(left, red 100px, yellow 200px);}


效果如:


左上方漸層

那從(100px, 100px)到(200px, 200px)應該就是從左上方開始,寫法如下:


{background-image:linear-gradient(left top, red 100px, yellow 200px);}


效果如下

漸層方向寫法組合:

left, right, top, bottom, left top, left bottom, right top, right, bottom
分別表示,從左往右,從右往左,從上往下,從下往上,從左上往右下,從……(都懂的,不全寫了)
當然,也可以用angle角度來寫!


{background-image:linear-gradient(-45deg, red 100px, yellow 200px);}


具體的樣式大家可以嘗試著寫一下,看一下!很多情況下,用了才知道!

注意:有不少效果加了-webkit首碼以及-moz首碼會展現的不一樣!

例如:

background-image:-webkit-linear-gradient(-45deg, red, yellow)

background-image:linear-gradient(-45deg, red, yellow)
在Chrome瀏覽器下的漸層方向居然是相反的!但是45deg是正常的。Firefox瀏覽器下也是如此,有首碼和沒有首碼方向相反!咋回事?

原因很簡單,CSS3目前還是草案階段!

從瀏覽器去掉首碼前後的變化可以推測,之前,W3C的漸層座標是與photoshop中一致的,但是,後來,由於某些原因,修改了。

至於什麼原因,根據我草草的尋找,可能與下面幾個關鍵字之一有聯絡:animation/transition動畫、write-mode書寫方向、flex box模型、以及radial-gradient漸層等。在這裡就不深入研究了!

首碼相容

基本的寫法如下:


 background-image: linear-gradient(top, #fff, #dededc);


但是為了相容,有時候要寫多個首碼,變成如下:


background-image: -ms-linear-gradient(top, #fff, #dededc);    background-image: -moz-linear-gradient(top, #fff, #dededc);    background-image: -webkit-gradient(linear, left top, left bottom, from(#fff), to(#dededc));    background-image: -webkit-linear-gradient(top, #fff, #dededc);    background-image: -o-linear-gradient(top, #fff, #dededc);    background-image: linear-gradient(top, #fff, #dededc);

關於”css3實現一個p設定多張背景圖片及background-image屬性“今天就寫到這裡,有問題可以相互交流,加油!

相關文章

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.