星空网 > 软件开发 > 网页设计

CSS3中的background-size(对响应性图片等比例缩放)

background-size的基本属性

background-size: 可以设定背景图像的尺寸,该属性是css3中的,在移动端使用的地方很多,比如最常见的地方在做响应性布局的时候,比如之前做的项目中有轮播图片,为了自适应不同大小分辨率的图片,我门需要使用css3中的媒体查询来针对不同的分辨率设置宽度和高度,虽然这种方式是可以解决问题,但是解决方式并不是太好,并且很繁琐,当然我门也想过直接使用百分比设置图片的大小,比如width(宽度): 100%,height(高度):100%; 但是设置图片等高度100%的时候并不生效,图片没有显示出来,因为没有设置具体的高度值,浏览器渲染的时候并没有高度,因此当时解决的方法是使用css3中的媒体查询真对不同的分辨率等比例缩放不同的height(高度)。

浏览器支持的程度:IE9+, Firefox4+, opera, chrome, safari5+;

基本语法:background-size: length | percentage | cover | contain; 

一:length

    该属性值是设置背景图像的宽度和高度的,第一个值是宽度,第二个值是设置高度的。如果只设置第一个值,那么第二个值会自动转换为 “auto”;

二:percentage

     该属性是以父元素的百分比来设置图片的宽度和高度的,第一个值是宽度,第二个值是高度。如果只设置一个值,那么第二个值会被设置为 “auto”;

三:cover

      把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。

四:contain

      把图像扩展至最大尺寸,以使宽度和高度 完全适应内容区域。

设置固定宽度400px和高度200px后的图片

1 <div class="bsize1"></div>

1 .bsize1 {2    width:400px;3    height:200px;4    background: url("1.jpg") no-repeat;5    border:1px solid red;6    overflow: hidden;7  }

CSS3中的background-size(对响应性图片等比例缩放)

固定宽度400px和高度200px-使用background-size:400px 200px缩放设置或者使用background-size:100% 100%缩放设置

1 <div class="bsize1 bsize3"></div>

1 .bsize3 {2      background-size: 400px;3     /*background-size:100% 100%;*/4 }  

CSS3中的background-size(对响应性图片等比例缩放)

固定宽度400px和高度200px-使用background-size:100%的缩放设置

1 <div class="bsize1 bsize5"></div>

1 .bsize5 {2      background-size: 100%;3  }

CSS3中的background-size(对响应性图片等比例缩放)

 

使用属性cover来设置背景图片

1 <div ></div>

.cover {    background-size:cover; }

CSS3中的background-size(对响应性图片等比例缩放)

使用属性contain来设置背景图片

<div class="bsize1 contain"></div>

.contain {    background-size:contain; }

CSS3中的background-size(对响应性图片等比例缩放)

给图片设置width属性100%;高度自适应

不使用背景图片等情况下,给图片设置属性 width = 100%,它的高度会自适应的。如下HTML代码:

<div class="bsize-padding"><img src='/images/loading.gif' data-original="3.jpg" width="100%"/></div>

CSS3中的background-size(对响应性图片等比例缩放)

使用另一种方式来解决图片自适应的问题--图片自适应问题

图片宽度设置100%,页面加载时会存在高度塌陷的问题,可以使用padding-top来设置百分比值来实现自适应 padding-top = (图片的高度/图片的宽度)*100;

<p>可以使用padding-top来设置百分比值来实现自适应 padding-top = (图片的高度/图片的宽度)*100</p><div class="cover-paddingTop">   <img src='/images/loading.gif' data-original="5.jpg"/></div>

.cover-paddingTop {    position: relative;    padding-top: 50%;    overflow: hidden; } .cover-paddingTop img{   width:100%;   position: absolute;   top:0; }

CSS3中的background-size(对响应性图片等比例缩放)

使用padding-top:(percentage)实现响应式背景图片

实现的基本原理:将使用到保持元素的宽高比的技巧,为元素添加垂直方向的padding-top的值,使用百分比的形式,这个值是相对于元素的宽而定的,比如我上面的一张图片的宽度是1024px,高度为316px;那么现在的

padding-top = (高度 / 宽度 )*100% = (316 / 1024)* 100% =  30.85%;

但是仅仅对图片高度和宽度缩放的放还不够,我门还必须添加 background-size:cover, 使这个属性让背景铺满元素的,但是IE8及以下不支持该属性,因此为了兼容IE下面的浏览器,我门还需要再加一个属性 background-position: center ; 同时我门也要保证 图片的宽度最大等于父容器的宽度;因此下面的HTML代码如下:

<div class="column">  <div class="figure"></div></div>

.column{    max-width: 1024px; } .figure {     padding-top:30.85%; /* 316 / 1024 */     background: url("6.jpg") no-repeat;     background-size:cover;     background-position:center;  }

CSS3中的background-size(对响应性图片等比例缩放)

 




原标题:CSS3中的background-size(对响应性图片等比例缩放)

关键词:CSS

CSS
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

又被恶意投诉:https://www.goluckyvip.com/tag/5919.html
澳大利亚的标志物:https://www.goluckyvip.com/tag/59199.html
格力营收:https://www.goluckyvip.com/tag/592.html
海运价格暴涨:https://www.goluckyvip.com/tag/5920.html
澳大利亚的标志建筑物:https://www.goluckyvip.com/tag/59200.html
澳大利亚的标志建筑:https://www.goluckyvip.com/tag/59202.html
武陵山大裂谷周围景点 武陵山大裂谷周围景点图片:https://www.vstour.cn/a/411233.html
南美旅游报价(探索南美洲的旅行费用):https://www.vstour.cn/a/411234.html
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流