你不知道的CSS背景—css背景屬性全解

来源:http://www.cnblogs.com/star91/archive/2016/08/26/5811161.html
-Advertisement-
Play Games

CSS背景在網頁設計中使用頻率非常高,然而對於這個開發人員很熟悉的CSS屬性,卻隱藏著許多不為初級開發人員熟知的細節,這篇文章嘗試扒開這層不為人知的面紗。 首先列舉一下CSS中關於元素背景的所有屬性並簡要描述了其作用,其中後面幾個屬性是在CSS3中新加入的。 下麵一一“理清”這些屬性 backgro ...


 

 

CSS背景在網頁設計中使用頻率非常高,然而對於這個開發人員很熟悉的CSS屬性,卻隱藏著許多不為初級開發人員熟知的細節,這篇文章嘗試扒開這層不為人知的面紗。

 

首先列舉一下CSS中關於元素背景的所有屬性並簡要描述了其作用,其中後面幾個屬性是在CSS3中新加入的。

屬性 描述 備註
background 簡寫屬性,作用是將背景屬性設置在一個聲明中。  
background-color 設置元素背景顏色  
background-image 把圖像設置為背景  
background-repeat 設置背景圖像是否及如何重覆。 僅作用與背景圖片,不會影響背景顏色
background-position 設置背景圖像的起始位置。 僅作用與背景圖片,不會影響背景顏色
background-attachment 背景圖像是否固定或者隨著頁面的其餘部分滾動。 僅作用與背景圖片,不會影響背景顏色
background-origin 規定背景圖片的定位區域。 CSS3,僅作用與背景圖片,不會影響背景顏色
background-clip 規定背景的繪製區域。 CSS3同時作用域背景圖片和背景顏色
background-size 規定背景圖片的尺寸。 CSS3

 

下麵一一“理清”這些屬性

background這個複合屬性就不多說了,它可以將其他的屬性值寫在一起

 

1 background:[<background-color>] [,background-image] [,background-repeat] [,background-attachment] [,background-position]...

1.background-color

background-color可以使用十六進位顏色、RGB顏色、RGBA顏色、HSL色彩、HSLA顏色 、顏色關鍵字等表示的顏色 ,然而很多初級開發者不清楚的是backgroud-color在元素盒模型中覆蓋的範圍是多大。下麵我們測試一下:

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 <!DOCTYPE html> <html lang="en"> <head>     <meta charset="UTF-8">     <title>Document</title>     <style type="text/css">         *{             margin: 0px;             padding: 0px;         }         div{             width: 400px;             height: 200px;             margin: 20px;             padding: 15px;             border: 10px dotted red;             background-color: green;                }     </style> </head> <body>     <div>     </div>    </body> </html>

為了驗證背景顏色有沒有鋪蓋到邊框,這裡設置了邊框的樣式為點線形式,在現代標準瀏覽器中測試(包括IE8及以上)如下左圖所示,而在IE6環境中測試如下右圖所示。

                         

 

所以結論是:CSS2元素顏色背景的顯示範圍與CSS2.1CSS3並不相同。在CSS2中(支持IE6),顏色背景的顯示範圍是指內部留白(包括padding)之內的範圍,不包括邊框;在CSS2.1CSS3中(包括IE8以上測試),背景在整個盒模型中,它是佈滿整個元素的盒子區域的(但是仍然不包括外邊margin範圍)

 

2.background-image:none || <url> 

元素的圖片背景是元素的總大小,包括paddingborder(但不包括margin)。預設情況下,background-image放置在元素的左上角,並重覆垂直和水平方向(後面會講到background-position預設值為0% 0%,background-repeat預設是repeat),background-color的預設覆蓋範圍是相同的,在現代標準瀏覽器中鋪滿padding和border,在IE6中卻不包括邊框。

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 <style type="text/css">         *{             margin: 0px;             padding: 0px;         }         div{             width: 400px;             height: 200px;             margin: 20px;             padding: 15px;             border: 10px dotted red;             background-color: green;             background-image: url(images.jpg);                     }   </style>

左圖為現代標準瀏覽器,在IE瀏覽器中測試,可以將其渲染模式設置為IE6.

         

 

 

 

3.background-repeat:repeat(預設)||repeat-x||repeat-y||no-repeat 

background-repeat屬性非常好理解,可以決定圖片背景是否在水平或者垂直方向重覆,其預設值是repeat,即在兩個方向都重覆。然而,很多初級開發者不知道的是,當設置background-repeat為no-repeat時,在現代標準瀏覽器中圖片背景的覆蓋範圍會發生變化,下麵測試一下:

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 <style type="text/css"> *{     margin: 0px;     padding: 0px; } div{     width: 400px;     height: 200px;     margin: 20px;     padding: 15px;     border: 10px dotted red;     background-color: green;     background-image: url(test.jpg);     background-repeat: no-repeat;       }   </style>

這裡換上了一個比div要大的圖片,左圖為現代標準瀏覽器的測試結果,右圖為IE6中測試結果。

 

          

 

可以很明顯的發現,左圖中,上邊框和左邊框沒有被圖片背景覆蓋,露出了綠色的背景顏色。而在IE6環境中表現並沒有發生變化。

 

4.backgroud-positon:%x %y|| xpos ypos||關鍵字 

設定背景位置時可以使用三種值:關鍵字、百分比、絕對或相對單位的數值關鍵字為leftright、與topbottomcenter的組合 ,可以使用兩個值 分別設定水平和垂直位置。 關鍵字指的順序不重要, left bottom  bottom left 意思相同。為了設定的值在所有瀏覽器中都有效,最好不要混用關鍵字值與數字值。 使用數值(比如 40% 30%)時,第一個值表示水平位置,第二個值表示垂直位置。要是只設定 一個值,則將其用來設定水平位置,而垂直位置會被設為 center。 

需要註意的是:在使用關鍵字和百分比值的情況下,設定的值同時應用於元素和圖片。換句話說,如果設定了33% 33%,則圖片水平 33%的位置與元素水平 33%的位置對齊。垂直方面也一樣。可以通過 center center 把圖片的中心點定位在了元素的中心點。像素之類的絕對單位數值就不一樣了。要是用像素單位來設定位置,那麼圖片的左上角會被放在距離元素左上角指定位置的地方。 

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 <style type="text/css">         *{             margin: 0px;             padding: 0px;         }         div{             width: 400px;             height: 200px;             margin: 20px;             padding: 15px;             border: 10px dotted red;             background-color: green;             background-image: url(images.jpg);             background-position: 50% 50%;               }       </style>

左圖為現代標準瀏覽器,右圖為IE6,可以看到圖片被定位到正中間,併在水平和垂直方向重覆,這也說明瞭使用百分比設置定位時是同時作用在元素和背景圖片上的,如若不然,圖片應該位於黃色方框所在的位置。

                            

 

 

 接下來我們刨根問底,background-position的預設定位起始點是哪裡?是邊框?還是內留白padding?

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 <style type="text/css">         *{             margin: 0px;             padding: 0px;         }         div{             width: 400px;             height: 200px;             margin: 20px;             padding: 15px;             border: 10px dotted red;             background-color: green;             background-image: url(images.jpg);             background-position: 10px 10px;             /*background-repeat: no-repeat;*/                       }     </style>

                                  

 

 

從圖中我們找到沿水平和垂直方向重覆前的原始圖片,如圖中黃色方框所示,在css中我們設置的background-position:10px 10px;整個數值正好是邊框的寬度,如果定位起點是邊框外邊緣,則圖片的左上角應該位於邊框左上角外邊緣,而實際顯示卻不是,圖片起點是相對於邊框內邊緣或者說內留白padding的外邊緣定位的,然後水平和垂直重覆鋪滿包括邊框的區域。

如果加上background-repeat: no-repeat效果更容易看出來,下圖是現代標準瀏覽器的測試結果,

                   

 

 

有意思的是,還可以使用負值。這樣就可以把圖片的左上角定位到元素外部,從而在元素中只 能看到部分圖片。當然,給background-position設定足夠大的正值,也可以把圖片的右下角推到元素外部,從 

而在元素中也只能看到部分圖片,甚至把讓個背景圖片元素外部,位於元素外部的那部分圖片不會顯示這也沒什麼實際意義了。既然background-position可以設置負值,我們考慮第3節出現的問題:當設置background-repeatno-repeat時,上邊框和左邊框沒有被圖片背景覆蓋。

 

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 <style type="text/css">         *{             margin: 0px;             padding: 0px;         }         div{             width: 400px;             height: 200px;             margin: 20px;             padding: 15px;             border: 10px dotted red;             background-color: green;             background-image: url(test.jpg);            &nbs
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.什麼是Code Mirror 最近做一個項目需要在網頁上實現一個代碼編輯器,支持語法高亮、自動縮進、智能提示等功能。發現Code Mirror剛好滿足所有需求。Code Mirror是由js寫的一款插件,其功能非常強大,用來實現網頁端代碼編輯器非常方便。如果想看效果圖,可移步到這裡 CodeOn ...
  • Definition 瀑布流佈局,在視覺上表現為參差不齊的多欄佈局,隨著頁面滾動條向下滾動,新數據不斷被載入進來。 瀑布流對於圖片的展現,是高效而具有吸引力的,用戶一眼掃過的快速閱讀模式可以在短時間內獲得更多的信息量,而瀑布流里懶載入模式又避免了用戶滑鼠點擊的翻頁操作。 瀑布流的主要特性便是錯落有致 ...
  • 一、 Date對象 定義:Date()可以返回系統當天的日期和時間; 註意:返回的是標註的時間格式 Sun Aug 07 22:50:03 2016 用法: 1.1 獲取時間對象 1.2 轉換成時間對象 1.3 Date.parse把日期格式的字元串轉換成毫秒形式,如果日期格式不正確,返回NaN 1 ...
  • github地址:https://github.com/lily1010/sass/tree/master/course02 用到的sass語法是: sass --watch test.scss:test.css --style compact --style expanded 如下圖: 1 類名嵌 ...
  • 1. == (o゜▽゜)o☆[BINGO!] Javascript有兩組相等運算符,一組是==和!=,另一組是 和!==。前者只比較值的相等,後者除了值以外,還比較類型是否相同。 請儘量不要使用前一組,永遠只使用 和!==。因為==預設會進行類型轉換,規則十分難記。如果你不相信的話,請回答下麵五個判 ...
  • 實際項目中li和裡邊的數值是動態生成的,需要控制它的寬度和顏色,效果如圖: 如果能實現顏色按數值規律變化就好了,目前顏色是固定到數組中的。 實例代碼如下: <!DOCTYPE html><html><head> <meta charset="utf-8"> <title></title> <styl ...
  • 今天在網上參觀到一個寫法,返回字元串個個字母的個數 得到:Object {a: 5, b: 2, c: 2} reduce我查到是es5新加了array函數,這裡不細說,有興趣自己查; 關鍵是‘=>’,是我第一次在js中見到;在網上查了查沒找到什麼資料,自己理解吧,希望有大神指正。 應該就是匿名函數 ...
  • 我們做項目的時候,經常遇到樣式層疊問題,被其他的樣式覆蓋,或者寫的權重不高沒效果,對權重沒有具體的分析,做了一個總結。 如下圖,css規則由選擇器和聲明塊組成,寫在選擇器後面大括弧里的就叫聲明。 一、樣式類型1、行間 2、內聯 3、外部 例子彙總html: style1.css style2.css ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...