zoukankan      html  css  js  c++  java
  • background-size的兼容性

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

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

    1 picLUp{
    2     background:url(logo.png)no-repeat;
    3     100%;height:40%;
    4     background-size:100%100%;
    5 }

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

    语法

    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)格式的图片完全透明区域后面的内容。

    1 hello{
    2     10%;
    3     height:50%;
    4     position:absolute;
    5     filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='1.jpg',sizingMethod='scale');

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

    附上background-size属性:

    background-size:规定背景图像的尺寸
    
      1.length:设置背景图像的高度和宽度第一个值设置宽度,第二个值设置高度。如果只设置一个值,则第二个值会被设置为 "auto"。
      2.percentage:以父元素的百分比来设置背景图像的宽度和高度第一个值设置宽度,第二个值设置高度。如果只设置一个值,则第二个值会被设置为 "auto"。
      3.cover:把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。
      4.contain:把图像图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域。
    background-position:属性设置背景图像的起始位置。
    
      1.有left,top,right,bottom,center五个值组合显示位置。如果只写第一个,第二个省略默认center。
      2.x% y%:第一个值是水平位置,第二个值是垂直位置。左上角是 0% 0%。右下角是 100% 100%。如果您仅规定了一个值,另一个值将是 50%。
      3.Xpx Ypx: 第一个值是水平位置,第二个值是垂直位置。
  • 相关阅读:
    5分钟带你了解Kafka的技术架构
    聊聊我的知识体系
    你分得清楚Maven的聚合和继承吗?
    为抖音而生的多闪,如何获取抖音的用户数据?
    消息中间件系列第3讲:使用消息队列需要考虑的几个问题
    消息中间件系列第2讲:如何进行消息队列选型?
    消息中间件系列第1讲:为什么要用消息队列?
    JVM规范系列开篇:为什么要读JVM规范?
    安全编码实践之三:身份验证和会话管理防御
    安全编码实践之二:跨站脚本攻击防御
  • 原文地址:https://www.cnblogs.com/emma-post/p/10023669.html
Copyright © 2011-2022 走看看