如何用CSS实现背景图片自适应?

HTML中通过CSS设置背景图片自适应浏览器大小,该如何实现?

CSS背景图


background-size属性,你想给他多大的百分比都可以,不设置表示默认图片大小,设置100%表示全屏显示图片,按比例缩小或者放大。

例如:

.picLUp{background:url(http://img.w3cschool.cn/attachments/knowledge/201610/14632.png) no-repeat;width:100%;height:40%;background-size:100%100%;}

这样就可以实现背景图片自适应父容器大小而自动变化,达到填充效果。 但是,图片会被拉伸填充,这并不是我们想要的效果,那么我们可以不设置100%参数,而是使用cover参数。

background-size:cover

设置cover参数以后,背景图会按比例缩放填充满整个背景。

如果使用IE浏览器你会发现,上面的background-size:100% 100%;并没有起到作用,图片原本是怎样就怎样显示,比较大就只能显示一部分。

所以这时需要使用IE特有的滤镜 AlphaImageLoader 兼容性在IE5.5+以上版本的浏览器上都可以完美运行。

AlphaImageLoader 语法:

filter: progid:DXImageTransform.Microsoft.AlphaImageLoader ( enabled=bEnabled , sizingMethod=sSize , src=sURL )

AlphaImageLoader 属性:

enabled: 可选项。布尔值(Boolean)。设置或检索滤镜是否激活。true|false_ true: 默认值。滤镜激活。

false: 滤镜被禁止。

sizingMethod: 可选项。字符串(String)。设置或检索滤镜作用的对象的图片在对象容器边界内的显示方式。

crop: 剪切图片以适应对象尺寸。

image: 默认值。增大或减小对象的尺寸边界以适应图片的尺寸。

scale: 缩放图片以适应对象的尺寸边界。

src: 必选项。字符串(String)。使用绝对或相对 url 地址指定背景图像。假如忽略此参数,滤镜将不会作用。

特性:

Enabled: 可读写。布尔值(Boolean)。参阅 enabled 属性。

sizingMethod: 可读写。字符串(String)。参阅 sizingMethod 属性。

src: 可读写。字符串(String)。参阅 src 属性。

说明:

在对象容器边界内,在对象的背景和内容之间显示一张图片。并提供对此图片的剪切和改变尺寸的操作。如果载入的是PNG(Portable Network Graphics)格式,则0%-100%的透明度也被提供。

PNG(Portable Network Graphics)格式的图片的透明度不妨碍你选择文本。也就是说,你可以选择显示在PNG(Portable Network Graphics)格式的图片完全透明区域后面的内容。

hello{width:10%;height:50%;position:absolute;filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='http://img.w3cschool.cn/attachments/knowledge/201610/14632.png',sizingMethod='scale');}

这样我们就可以完美兼容绝大多数的浏览器,实现用CSS让背景图片100%填充了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,792评论 0 2
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    love2013阅读 2,328评论 0 11
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,510评论 0 17
  • background-size: length|percentage|cover|contain;IE9+、Fir...
    Mr慢悠悠阅读 6,878评论 0 1
  • 第一次认识你应该是在豆瓣里的影评,呵呵,没办法,我就是这一个很喜欢偷懒的人。总是,喜欢在豆瓣上搜罗一堆评分...
    転調阅读 371评论 5 2