• 本网豪情赞助商

  • login failed for display 0 ubuntuallowed_u
  • css设定文本超出一行或多行就隐藏并显示省略
  • css设定文本超出一行或多行就隐藏并显示省略
  • 微信小程序如何把接口调用成功的回调函数返回
  • CodeIgniter - 数据库的增删改查
  • php生成excel的三种方式
  • 小程序UI库推荐
  • 多个句子竖向排列
  • 美团,大众点评,58城市行政区域和商圈数据实
  • java.security.InvalidKeyException: Illega
  • h3>

    纯CSS控制背景图片100%自适应填充布局


    文章摘要: 问说网 发布于 2015-05-09 字数3300 浏览 13702 评论 0 以往的背景图片都是死的,换句话说就是原来是什么样,那么我们就无法修改了,这里是指他的尺寸等,CSS中新引入了 Background-size 属性,我们可以使用他来给我们的背景添加一些特别的效果。 做响应式布


    文章TAG:

     

    问说网 · 发布于 2015-05-09 · 字数3300 · 浏览 13702 · 评论 0

    以往的背景图片都是“死的”,换句话说就是原来是什么样,那么我们就无法修改了,这里是指他的尺寸等,CSS中新引入了Background-size属性,我们可以使用他来给我们的背景添加一些特别的效果。

    唯美背景

    做响应式布局的时候,如果有背景图,我们当然希望他能够全屏100%显示,这样显得页面非常的爆满,不过这又出现了一个问题,图片的尺寸多大合适呢,现在的浏览器分辨率参差不齐,对于Firefox等高级的浏览器,使用Background-size设置为100%即可,而IE浏览器就需要不同设置。

    背景100%填充

    在Firefox中,只需要用background-size则可以控制其随容器的大小而自动伸缩

    .picLUp{
        background:url(logo.png) no-repeat;
        width:100%;
        height:40%;
        background-size:100% 100%;
    }

    在这样的CSS控制之下,则可以在Firefox中达到背景图片随父容器大小而自动变化,达到填充效果,图片会被拉伸填充,这并不是我们想要的效果,那么我们可以不设置100%参数,而是使用cover参数。

    background-size:cover

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

    针对IE浏览器

    但是在IE之下,你会发现上面的CSS控制会很不理想,它并不会因为你有了background-size:100% 100%;而自动缩放,图片原本怎么样就怎么样显示,如果容器比图片小,则只能显示图上的一部分,那么要达到这个效果,则需要使用IE特有的滤镜。

    AlphaImageLoader

    AlphaImageLoader兼容性在IE5.5+以上版本的浏览器上都可以完美运行。

    语法

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

    属性

    • 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='1.jpg',sizingMethod='scale');
    }

    通过上面两种方法的介绍,我们就可以完美兼容所有的浏览器,使用CSS让背景图100%填充。