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

阅读目录

  • background-size的基本属性
  • 给图片设置固定的宽度和高度的
  • 固定宽度400px和高度200px-使用background-size:400px 200px缩放设置
  • 固定宽度400px和高度200px-使用background-size:400px;的缩放设置,那么第二个参数会自动转换为auto
  • 固定宽度400px和高度200px-使用background-size:100% 100%的缩放设置
  • 固定宽度400px和高度200px-使用background-size:100%的缩放设置
  • 使用属性cover来设置背景图片
  • 使用属性contain来设置背景图片
  • 给图片设置width属性100%;高度自适应
  • 使用另一种方式来解决图片自适应的问题--图片自适应问题
  • 使用padding-top:(percentage)实现响应式背景图片
回到顶部

background-size的基本属性

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

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

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

一:length

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

二:percentage

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

三:cover

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

四:contain

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

回到顶部

给图片设置固定的宽度和高度的

下面我门来做一些demo来实现下上面的几个属性值的基本使用方法;

基本的原图的html代码如下:

<h3>原图</h3>
<div class="images"><img src="http://images2015.cnblogs.com/blog/561794/201603/561794-20160310002800647-50077395.jpg" width="100%"/></div>

效果如下图所示:

给图片设置固定的宽度和高度的代码如下:

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

HTML代码如下:

<h3>固定宽度400px和高度200px后的图片</h3>
<div class="bsize1"></div>

css代码如下:

.bsize1 {width:400px;height:200px;background: url("http://images2015.cnblogs.com/blog/561794/201603/561794-20160310002800647-50077395.jpg") no-repeat;border:1px solid red;overflow: hidden;}

效果如下:

回到顶部

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

2. 固定宽度400px和高度200px-使用background-size:400px 200px缩放设置;

HTML代码如下:

<h3>固定宽度400px和高度200px-使用background-size:400px 200px缩放设置</h3>
<div class="bsize1 bsize2"></div>

css代码如下:

.bsize2 {background-size: 400px 200px;}

效果如下:

回到顶部

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

3. 固定宽度400px和高度200px-使用background-size:400px;的缩放设置,那么第二个参数会自动转换为auto;

HTML代码如下:

<h3>固定宽度400px和高度200px-使用background-size:400px;的缩放设置</h3>
<div class="bsize1 bsize3"></div>

css代码如下:

.bsize3 {background-size: 400px;}

效果如下:

回到顶部

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

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

HTML代码如下:

<h3>固定宽度400px和高度200px-使用background-size:100% 100%的缩放设置</h3>
<div class="bsize1 bsize4"></div>

css代码如下:

.bsize4 {background-size:100% 100%;}

效果如下:

回到顶部

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

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

HTML代码如下:

<h3>固定宽度400px和高度200px-使用background-size:100%的缩放设置</h3>
<div class="bsize1 bsize5"></div>

css代码如下:

.bsize5 {background-size: 100%;}

如下所示:

回到顶部

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

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

HTML代码如下:

<h3>使用属性cover来设置背景图片</h3>
<div class="bsize1 cover"></div>

css代码如下:

.cover {background-size:cover;}

效果如下:

回到顶部

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

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

HTML代码如下:

<h3>使用属性contain来设置背景图片</h3>
<div class="bsize1 contain"></div>

css代码如下:

.contain {background-size:contain;}

效果如下:

回到顶部

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

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

<h3>给图片设置属性宽度为100%的情况下,可自适应图片</h3>
<div class="bsize-padding"><img src="http://images2015.cnblogs.com/blog/561794/201603/561794-20160310002800647-50077395.jpg" width="100%"/></div>

效果如下:

回到顶部

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

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

如下HTML代码:

<h3>图片自适应问题,图片宽度设置100%,页面加载时会存在高度塌陷的问题</h3>
<p>可以使用padding-top来设置百分比值来实现自适应 padding-top = (图片的高度/图片的宽度)*100</p>
<div class="cover-paddingTop"><img src="http://images2015.cnblogs.com/blog/561794/201603/561794-20160310002800647-50077395.jpg"/></div>

css代码如下:

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

效果如下:

回到顶部

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

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

我门都知道,处理在响应性布局的时候,背景图片都是等比例缩放,比如上面的使用图片的情况,使用<img /> 引入的图片的话,那么设置她们的width属性为100%;<img src=”” width=”100%”/> 的话,高度就会等比例缩放,这是图片,但是如果是背景图片呢?我门之前的项目中的常见的做法是根据css3媒体查询的方法来做的,根据不同手机的分辨率等不同,来等比例缩放背景图的高度,虽然这种方式是可以解决问题的,但是这种通过人肉的方式来进行设置并不好,也很繁琐,今天我门来学习使用padding-top这么一个属性来设置了;

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

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

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

<h3>使用padding-top实现响应性图片(图片的宽度是1024px,高度是316px)</h3><div class="column"><div class="figure"></div></div>

css代码如下:

.column{max-width: 1024px;}.figure {padding-top:30.85%; /* 316 / 1024 */background: url("http://images2015.cnblogs.com/blog/561794/201603/561794-20160310002800647-50077395.jpg") no-repeat;background-size:cover;background-position:center;}

效果如下:

注意:具体的效果可以自己复制代码到浏览器运行下即可~

转载于:https://www.cnblogs.com/tugenhua0707/p/5260411.html

理解CSS3中的background-size(对响应性图片等比例缩放)相关推荐

  1. jquery实现图片等比例缩放,解决max-width在ie中不兼容问题

    上次用原生的JavaScript实现的图片等比例缩放,max-width和max-height在ie6中不兼容问题,今天用jQuery实现了这些问题 jQuery部分代码 <script typ ...

  2. CSS3中的变形处理--transform功能(旋转、缩放、倾斜、移动)

    1.transform属性 在CSS3中,可以利用transform功能实现文字或图像的旋转.缩放.倾斜.移动这4中类型的变形处理. (1)浏览器支持 到目前为止:Safari3.1以上.Chrome ...

  3. CSS3中的变形处理——transform功能(旋转、缩放、倾斜、移动)

    1 transform属性 在CSS3中,可以利用transform功能实现文字或图像的旋转.缩放.倾斜.移动这4中类型的变形处理. (1)浏览器支持 到目前为止:Safari3.1以上.Chrome ...

  4. HTML背景渐变圆圈,背景渐变:html5+css3中的background: -moz-linear-gradient 用

    在CSS中background: -moz-linear-gradient 让网站背景渐变的属性,目前火狐3.6以上版本和google浏览器支持这个属性. 背景使用CSS渐变显示可以不使用图像就实现两 ...

  5. html5+css3中的background: -moz-linear-gradient 用法

    http://hi.baidu.com/zyyhyzazwm/item/72dc6c9a40513acf1a49df56 在CSS中background: -moz-linear-gradient 让 ...

  6. 深入理解css3中的flex-grow、flex-shrink、flex-basis (转)

    转自:http://zhoon.github.io/css3/2014/08/23/flex.html   感谢他的整理 flex为css的布局带来了新的时代,作为一个重构工程师,我们再也不用局限于f ...

  7. CSS3中的 Background linear gradient()用法

    本文参考自css only muti-color background如有兴趣的同学可以去看看这篇文章 这篇文章主要通过几个例子看看linear-gradient()的具体用法对linear-grad ...

  8. css3中的background

    对background的两种运用:一是background中的线性渐变,background: linear-gradient(to bottom,#0e7bef,#0d73da);这个是对背景颜色从 ...

  9. php gd库 缩小图片_【源码分享】PHP中GD库实现图片等比例缩放

    //定义必备参数 $path = "./images"; $picname = "6.jpg"; $maxW = 200; //指定要缩放到的宽度 $maxH ...

最新文章

  1. Android Java虚拟机拦截技术分析
  2. UC伯克利博士尤洋回国创业,求学期间破ImageNet纪录!已获超千万种子轮融资
  3. c++ string类 用法简介
  4. python爬虫代码房-小白学习python爬虫,分享一下代码,伪链家全站。
  5. Mybatis-Plus的SQL语句组拼原理
  6. 更改计算机语言win7,windows7专业版怎么更改语言_如何更改windows7专业版语言
  7. Atitit.java expression fsm 表达式词法分析引擎 v2 qaa.docx
  8. Render to Disk
  9. 二、逻辑回归LR面试题总结
  10. 千钧一发之际赢得暂缓令,苹果App Store要反败为胜了?
  11. 相似度测试的软件,Plagiarism Checker X(文章相似度检测软件) V6.08 官方版
  12. 支付宝支付-APP支付服务端详解
  13. PVE最小资源安装Jellyfin(LXC容器使用turnkey-mediaserver模板)
  14. 如何时重启打印机服务bat命令,打印机重启服务脚本 Win7打印机服务怎么开启 Win7开启打印机服务的设置的两种方法
  15. wifi 小程序 透传_微信小程序之一键连接wifi
  16. Autowired注解起什么作用呢?
  17. Spring Boot与Shiro实现权限管理02
  18. MySQL(十三):分区表( Partitioning Table)
  19. oracle佣金高于薪金60%,oracle的SQL练习题
  20. Netty面试题(史上最全)

热门文章

  1. springMVC九大组件及一次请求流程
  2. 操作系统(十四)进程调度的时机、调度方式
  3. 汇编语言位向量(位映射)
  4. 小型动漫知识图谱的构建 (Python+Neo4j) (纯实践内容,基于bilibili所有正版番剧的动漫、声优、角色、类型)
  5. Android 插件化原理解析——Hook机制之AMSPMS
  6. JZOJ 3401 JZOJ 5673. 【GDOI2018Day1模拟4.20】爬山法
  7. 动态给div追加html代码,javascript – 动态添加/删除div到html
  8. c++ vector 赋值_C++中vector用法
  9. iframe如何发送请求_插件分享 | 如何半天玩转一个“ES未授权利用”插件
  10. 三角形css_使用css绘制三角形