参考链接: 浅谈 css的zoom属性

  • zoom属性是ie浏览器的专有属性,它可以设置或者检索对象的缩放比例。设置或者更改一个已被呈递的对象的此属性值将导致环绕对象的内容重新流动。

重点:

  • 除了可以设置缩放比例,还可以触发ie的haslayout属性,清除浮动,清除margin重叠等作用。 不过值得注意的一点就是火狐浏览器不支持zoom属性,但是在webkit内核浏览器中zoom这个属性也是可以被支持的。

1、在非ie浏览器中

  • zoom在非IE浏览器中表现为支持放大或者缩小,但是由于这个属性是一个不标准的css属性,因此一般在非IE浏览器中不用zoom来实现div 的缩放效果,现在要放大或者缩小直接用css3的transform属性。

2、在ie浏览器中

(1)

  • zoom属性的使用方法:
    zoom:normal|number;
    normal是默认值。使用对象的实际尺寸
    number:百分数|无符号浮点数。(即方大的倍数,可为数值,也可为百分比)
    但这些在ie中才可以使用。

  • 最常用到的作用是:清除浮动

    .border{ 
    border:1px solid #CCC; 
    padding:2px; 
    overflow:hidden; 
    _zoom:1; 
    } 

    _zoom是CSS hack中专对IE6起作用的部分。IE6浏览器会执行zoom:1表示对象的缩放比例,但这里
    overflow:hidden;和_zoom:1;是连起来用的,作用是清除border内部浮动。
    同理,还可以使用同样方法清除margin属性在IE浏览器中的重叠问题:这就要提到zoom属性在IE中的第二个作用了,即
    兼容IE6、IE7、IE8浏览器,经常会遇到一些问题,可以使用zoom:1来解决,有如下作用:

(2)触发IE浏览器的haslayout ,解决ie下的浮动,margin重叠等一些问题。

用法:ie下子元素浮动时父元素不随之自动扩大的问题。

zoom在ie浏览器中常见作用总结

1、检查页面的标签是否闭合
2、样式排除法
3、模块确认法
4、检查是否清除浮动
5、检查ie下是否触发haslayout
6、边框背景调试法