搜尋
首頁web前端html教學CSS3:background-size背景图片尺寸属性_html/css_WEB-ITnose

background-size可以设置背景图片的大小,数值包括 长度length和百分比percentage。 并且会根据背景原点位置background-origin设置其图片覆盖的范围。那么下面我们一起来了解这个background-size属性吧。

background-size语法

w3c对background-size的语法规定如下:

属性名: background-size
属性值: * 其中 bg-size = [ | | auto ]{1,2} | cover | contain
初始值: auto auto
应用于: 所有元素
继承性:
百分比: 见下文注解
计算值: 根据指定

语法解释

1、length,percentage,根据给定长度值或者百分比来调整背景图片大小。auto为默认值,这三个值最小可重复一次,最大重复两次。对于这些值有以下解释:
第一个值为设置图片宽度,第二个值为图片的高度;但是不管是用什么值,都不能为负值
假如只给定一个值,那么第二个自动的为 'auto';
假如指定为percentage百分比值,那么背景图大小是根据相对的背景区域来做调整,这个背景区域是由background-origin来来决定的。这在上面已经有提到过了关于图片原点的讨论。这里有必要提到 假如background-attachment:fixed,那么其背景相对区域就是初始包含块也就是视窗。

/* 一个值: 这个值指定图片的宽度,那么第二个值为auto */background-size: autobackground-size: 50%background-size: 3embackground-size: 12px/* 两个值: 第一个值指定图片的宽度,第二个值指定图片的高度 */background-size: 50% autobackground-size: 3em 25%background-size: auto 6pxbackground-size: auto auto/*多重背景,请用逗号隔开,在CSS语法中凡语法后跟*或者#,都是可以无限重复的,但是必须用逗号隔开。 */background-size: auto, auto     /* 不要跟background-size: auto auto混淆了 */background-size: 50%, 25%, 25%background-size: 6px, auto, containbackground-size: inherit                       <ol>                                                     <li> 1 </li>                                <li> 2 </li>                                <li> 3 </li>                                <li> 4 </li>                                <li> 5 </li>                                <li> 6 </li>                                <li> 7 </li>                                <li> 8 </li>                                <li> 9 </li>                                <li> 10 </li>                                <li> 11 </li>                                <li> 12 </li>                                <li> 13 </li>                                <li> 14 </li>                                <li> 15 </li>                                <li> 16 </li>                                <li> 17 </li>                                <li> 18 </li>                                <li> 19 </li>                                <li> 20 </li>                       </ol>
代码laycode - v1.1

2、contain,按比例调整背景图片,使得其图片宽高比自适应整个元素的背景区域的宽高比,因此假如指定的图片尺寸过大,而背景区域的整体宽高不能恰好包含背景图片的话,那么其背景某些区域可能会有空白。看以下代码

.im-com{    width:200px;    height:50px;        background:url(http://img.xiaoho.com/mystar/mada4.jpg) no-repeat top left scroll;   /*图片的宽高为440*440,而元素相对区域高度为50*/     background-size:contain;}.im-com-1{    width:50px;    height:100px;       background:url(http://img.xiaoho.com/mystar/mada4.jpg) no-repeat top left scroll;   /*元素相对区域宽度为50*/     background-size:contain;}                       <ol>                                                     <li> 1 </li>                                <li> 2 </li>                                <li> 3 </li>                                <li> 4 </li>                                <li> 5 </li>                                <li> 6 </li>                                <li> 7 </li>                                <li> 8 </li>                                <li> 9 </li>                                <li> 10 </li>                                <li> 11 </li>                                <li> 12 </li>                                <li> 13 </li>                                <li> 14 </li>                                <li> 15 </li>                                <li> 16 </li>                       </ol>
代码laycode - v1.1

当图片恰好自适应铺满元素的宽度或者高度,那么元素的会有空白处存在,也就是图中红色框框都显示了空白。

2、cover,按比例调整背景图片,这个属性值跟contain正好相反,背景图片会按照比如自适应铺满整个背景区域。假如背景区域不足以包含背景图片的话,那么背景图片就会被咔嚓。

.im-com{    width:200px;    height:50px;        background:url(http://img.xiaoho.com/mystar/mada4.jpg) no-repeat top left scroll;   /*图片的宽高为440*440,而元素相对区域高度为50*/     background-size:cover;}.im-com-1{    width:50px;    height:100px;       background:url(http://img.xiaoho.com/mystar/mada4.jpg) no-repeat top left scroll;   /*元素相对区域宽度为50*/     background-size:cover;}                       <ol>                                                     <li> 1 </li>                                <li> 2 </li>                                <li> 3 </li>                                <li> 4 </li>                                <li> 5 </li>                                <li> 6 </li>                                <li> 7 </li>                                <li> 8 </li>                                <li> 9 </li>                                <li> 10 </li>                                <li> 11 </li>                                <li> 12 </li>                                <li> 13 </li>                                <li> 14 </li>                                <li> 15 </li>                                <li> 16 </li>                       </ol>
代码laycode - v1.1

当使用了cover这个值的时候,那么正好就跟contain相反,其会正好覆盖整个背景相对区域,但是背景图片的某些部分就看不见,如下图的狗的下半身和右侧身体显示不全。

说说背景图片计算值

假如说只是拿单一的数值或者具体数值来解释那理解起来应该不难,但假如用混合长度来说,可能会有点一下子明白不上来。

规范给了几个例子,不妨拿出来一下:先声明,所以的元素尺寸为 100*100

100% 100%背景图片将铺满整个内容区,假如说元素有固有宽高,那么背景图片铺满整个100*100背景区域div {    background-image: url(plasma.png);    background-repeat: no-repeat;    background-size: 100% 100%;    background-origin: content-box }背景图片调整为宽度为50*50,但是背景图片的原点位置为边框box而不是padding-boxp {    background-image: url(tubes.png);    background-size: 50% auto;    background-origin: border-box }背景图片尺寸调整为15*15para {    background-size: 15px 15px;    background-image: url(tile.png)}这是默认值,也就是auto auto,此时背景图片的尺寸将会是跟图片的固有尺寸一样.body {    background-size: auto;            /* 默认值 */    background-image: url(flower.png) }假如两个都是百分比,此时图片就会根据背景区域来按照宽高比自适应,此处背景图片为20*30,但是因为背景重复用了 'round'循环,因此背景区域高度划分了3个33.3等高区域,所以背景图片会自适应调整为20*33.3p {    background-image: url(chain.png);    background-repeat: no-repeat round;    background-size: 20% 30% }                       <ol>                                                     <li> 1 </li>                                <li> 2 </li>                                <li> 3 </li>                                <li> 4 </li>                                <li> 5 </li>                                <li> 6 </li>                                <li> 7 </li>                                <li> 8 </li>                                <li> 9 </li>                                <li> 10 </li>                                <li> 11 </li>                                <li> 12 </li>                                <li> 13 </li>                                <li> 14 </li>                                <li> 15 </li>                                <li> 16 </li>                                <li> 17 </li>                                <li> 18 </li>                                <li> 19 </li>                                <li> 20 </li>                                <li> 21 </li>                                <li> 22 </li>                                <li> 23 </li>                                <li> 24 </li>                                <li> 25 </li>                                <li> 26 </li>                                <li> 27 </li>                                <li> 28 </li>                                <li> 29 </li>                                <li> 30 </li>                                <li> 31 </li>                       </ol>
代码laycode - v1.1

在MND帮助文档中还提到了关于火狐的渐变图片背景问题,不过那是涉及到Firefox8,规范中不推荐同时使用px和auto,因为在8以前的火 狐浏览器不支持重复渲染,但是我在caniuse上看见的版本是31+,so,你就尽情的用吧。并且对于移动浏览器的支持还是非常的好的,请看下图可知, 除了opera8部分不支持以外:

应用场景

目前用到background-size的场景都是基于webapp的背景图上,大致的情况是,比如说最常见的logo作为某个元素的背景,但logo很复杂,假如说我们按照设计图上的去切片的话,那会有两种可能:
1、按照csser的分辨率去切片,比如高度为50px,logo被直接缩放到50px那就会很别扭,而且估计那那画面太美,你都不敢看;
2、按照射击湿设计的分辨率去切的话,有可能设计图的logo尺寸会很大,但是我们csser写的时候高度只有50px,那logo就会显示不全;

这时候background-size就发挥其重要的作用了,我们可以通过对背景图片大小的自适应缩放,而不会影响到起美观性又能全部显示我们所需要的效果。

直接甩出你的手机出来吧。。。↓

?

参考资料:
http://dev.w3.org/csswg/css-backgrounds/#background-size
https://developer.mozilla.org/en-US/docs/Web/CSS/background-size#Notes

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
了解HTML,CSS和JavaScript:初學者指南了解HTML,CSS和JavaScript:初學者指南Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML的角色:構建Web內容HTML的角色:構建Web內容Apr 11, 2025 am 12:12 AM

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

HTML和代碼:仔細觀察術語HTML和代碼:仔細觀察術語Apr 10, 2025 am 09:28 AM

htmlisaspecifictypefodyfocusedonstructuringwebcontent,而“代碼” badlyLyCludEslanguagesLikeLikejavascriptandPytyPythonForFunctionality.1)htmldefineswebpagertuctureduseTags.2)“代碼”代碼“ code” code code code codeSpassSesseseseseseseseAwiderRangeLangeLangeforLageforLogageforLogicIctInterract

HTML,CSS和JavaScript:Web開發人員的基本工具HTML,CSS和JavaScript:Web開發人員的基本工具Apr 09, 2025 am 12:12 AM

HTML、CSS和JavaScript是Web開發的三大支柱。 1.HTML定義網頁結構,使用標籤如、等。 2.CSS控製網頁樣式,使用選擇器和屬性如color、font-size等。 3.JavaScript實現動態效果和交互,通過事件監聽和DOM操作。

HTML,CSS和JavaScript的角色:核心職責HTML,CSS和JavaScript的角色:核心職責Apr 08, 2025 pm 07:05 PM

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

HTML容易為初學者學習嗎?HTML容易為初學者學習嗎?Apr 07, 2025 am 12:11 AM

HTML適合初學者學習,因為它簡單易學且能快速看到成果。 1)HTML的學習曲線平緩,易於上手。 2)只需掌握基本標籤即可開始創建網頁。 3)靈活性高,可與CSS和JavaScript結合使用。 4)豐富的學習資源和現代工具支持學習過程。

HTML中起始標籤的示例是什麼?HTML中起始標籤的示例是什麼?Apr 06, 2025 am 12:04 AM

AnexampleOfAstartingTaginHtmlis,beginSaparagraph.startingTagSareEssentialInhtmlastheyInitiateEllements,defiteTheeTheErtypes,andarecrucialforsstructuringwebpages wepages webpages andConstructingthedom。

如何利用CSS的Flexbox佈局實現菜單中虛線分割效果的居中對齊?如何利用CSS的Flexbox佈局實現菜單中虛線分割效果的居中對齊?Apr 05, 2025 pm 01:24 PM

如何設計菜單中的虛線分割效果?在設計菜單時,菜名和價格的左右對齊通常不難實現,但中間的虛線或點如何...

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器