CSS中zoom:1的做用
兼容IE六、IE七、IE8浏览器,常常会遇到一些问题,可使用zoom:1来解决,有以下做用:
触发IE浏览器的haslayout
解决ie下的浮动,margin重叠等一些问题。
HTML代码:css
1 <div class="h_mainbox"> 2 <h2>推荐文章</h2> 3 <ul class="mainlist"> 4 <li><a href="#" style="color:#0000FF" target="_blank">CSS</a></li> 5 <li><a href="#" style="color:#0000FF" target="_blank">oNew< /a></li> 6 </ul> 7 </div> 8 CSS代码:
9 .h_mainbox { border:1px solid #dadada; padding:4px 15px; background:url(../mainbox_bg.gif) 0 1px repeat-x; margin-bottom:6px; overflow:hidden} 10 .h_mainbox h2 { font-size:12px; height:30px; line-height:30px; border-bottom:1px solid #ccc; color:#555;} 11 .h_mainbox h2 span { float:right; font-weight:normal;} 12 .h_mainbox ul { padding:6px 0px; background:#fff;} 13 .mainlist { overflow:auto; zoom:1;} 14 .h_mainbox li { width:268px; float:left; height:24px; overflow:hidden; background:url(../icon3.gif) 0 6px no-repeat; padding:0px 5px 0px 18px; line-height:200;
加红色的那里就能够在IE六、IE七、IE8正常显示效果了。
css中的zoom的做用
一、检查页面的标签是否闭合
不要小看这条,也许折腾了你两天都没有解决的 CSS BUG 问题,却仅仅源于这里。毕竟页面的模板通常都是由开发来嵌套的,而他们很容易犯此类问题。
快捷提示:能够用 Dreamweaver 打开文件检查,通常没有闭合的标签,会黄色背景高亮。浏览器
二、样式排除法
有些复杂的页面也许加载了 N 个外链 CSS 文件,那么逐个删除 CSS 文件,找到 BUG 触发的具体 CSS 文件,缩小锁定的范围。工具
对于刚才锁定的问题 CSS 样式文件,逐行删除具体的样式定义,定位到具体的触发样式定义,甚至是具体的触发样式属性。url
三、模块确认法
有时候咱们也能够从页面的 HTML 元素出发。删除页面中不一样的 HTML 模块,寻找到触发问题的 HTML 模块。spa
四、检查是否清除浮动
其实有很多的 CSS BUG 问题是由于没有清除浮动形成的。养成良好的清除浮动的习惯是必要的,推荐使用 无额外 HTML 标签的清除浮动的方法(尽可能避免使用 overflow:hidden;zoom:1 的相似方法来清除浮动,会有太多的限制性)。翻译
五、检查 IE 下是否触发 haslayout
不少的 IE 下复杂 CSS BUG 都与 IE 特有的 haslayout 息息相关。熟悉和理解 haslayout 对于处理复杂的 CSS BUG 会事半功倍。推荐阅读 old9 翻译的 《On having layout》(若是没法翻越穿越伟大的 GFW,可阅读 蓝色上的转帖 )
快捷提示:若是触发了 haslayout,IE 的调试工具 IE Developer Toolbar 中的属性中将会显示 haslayout 值为 -1。调试
六、边框背景调试法
故名思议就是给元素设置显眼的边框或者背景(通常黑色或红色),进行调试。此方法是最经常使用的调试 CSS BUG 的方法之一,对于复杂 BUG 依旧适用。经济实惠还环保^^
最后想强调一点的是,养成良好的书写习惯,减小额外标签,尽可能语义,符合标准,其实能够为咱们减小不少额外的复杂 CSS BUG,更多的时候实际上是咱们本身给本身制造了麻烦。但愿你远离 BUG ,生活愈来愈美好。code