标签归档:css hack

使用JS修复让IE6开始支持高级CSS属性

早上的时候,同事给了一个地址,用JS来使IE6支持高级CSS属性,之前看到的也有很多,比如PNG的透明修复等,零零散散的东西很多,给我的感觉也不是很完整,代码参差不齐的,质量很差.这个代码库是Dean Edwards写的.个人感觉来说,质量应该非常棒吧.在它的页面上摆弄了一番,的确,css2的一些高级特性也开始支持了,不过貌似在IE6下有点缓慢,比如加载的时候有一些小刷新.有一些高级特性,从一个link进入的时候,没有效果.但是页面刷新一下就出来了.初步判定应该是JS没有完全load完毕,直接操作DOM元素产生的问题,但是基本上不影响使用效果.

另外值得特别说明的是,如果用户对页面的相应速度有要求的话,那么请注意了.用JS操作DOM本来就是非常消耗资源.(相对WEB应用来说,因为分配给浏览器的内存是有限的).并且使用JS来动态操作style,相当于重新渲染了一次页面.那么如果页面有过多的PNG,或者过多的:hover,last-child,first-child这样的CSS2的属性,会不会引起页面加载速度狂慢呢????先把地址发过来,稍后做一个简单的测试.

链接地址
请用IE6打开!否则看不到具体的效果.

续 (使用报告)
————————————————

如果有想要使用这个JS来修复浏览器渲染BUG的开发者请注意!此JS有几个不太方便处理的地方。首先浏览器的渲染已经说过了。经过在IE6下的测试,效果是相当的好!IE6加载下有一点点速度问题。大概是半秒钟的样子,会把参差不齐的元素对其。让杂乱的页面变的有序(基本上和FF的渲染布局一致)。大概10个DIV,2个table。十几条数据。但是此时如果使用JS进行DOM操作就会引发一系列的问题,比如页面使用IE9.JS修复完毕之后,再使用 document.body.appendChild(domobj).此时的页面会重新渲染一次,和我上面说的一样。而且效果看起来相当的难看。如果有需要使用的朋友请谨慎选择。另外值得特别指出的是 <script type=’text/javascript’ src=’ie9.js’></script>这样的JS一定要放在</body>前面哦,如果放在</head>之上的朋友,等着抓狂吧。

CSS hack 的文章

因为之前的公司都是应对在IE以及FF下,对IE6,IE7,FF做的多了. Safari,Google Chrome以及Opera的测试下做的少得去了…(万恶的IE6,狠狠的鄙视一下).看到阿里前端工程师zergine写的一片关于CSS hack整理的文章,觉得很不错,收藏下,共享给所有的前端工程师.

以下是正文内容

—————————————————————————–

CSSHack是在标准CSS没办法兼容各浏览器显示效果时才会用上的补救方法,在各浏览器厂商解析CSS没有达成一致前,我们只能用这样的方法来完成这样的任务.
我进行前端开发的时候,测试用的浏览器大致有:IE7,IE6,Opera9(文章撰写时版本为9.258825),Safari3(文章撰写时版本为3.0.4523.15),Firefox2(文章撰写时版本为2.0.0.11).
在正常的selector{property:value;}的基础上常会根据具体情况为相同元素使用Hack以达到浏览器间统一.
IE系列:
selector{+property:value;}在属性名前加上加号”+”,这个Hack只有IE系列可以识别.
selector{*property:value;}在属性名前加上星号”*”,这个Hack只有IE系列可以识别.
selector{_property:value;}在属性名前加上下划线”_”,这个Hack只有IE系列(除IE7外)识别.
*htmlselector{property:value;}在选择器上运用继承法*htmlselector,这个Hack只有IE系列(除IE7外)可以识别.
html/**/>bodyselector{property:value;}在选择器上运用继承法html/**/>bodyselector,这个Hack只有IE系列(除IE7外)可以识别.
selector{property/**/:value;}在属性名和冒号”:”之间加入注释,屏蔽IE6用.
selector/**/{property/**/:value;}在选择器和花括号”{“之间以及在属性名和冒号”:”之间加入注释,屏蔽IE5和IE6用(不屏蔽IE5.5).
select/**/{property:value;}在选择器和花括号”{“之间加入注释,屏蔽IE5用.
*+htmlselector{property:value!important;}在选择器上运用继承法*+htmlselector再加上!important,这个Hack只有IE7可以识别.
Firefox:
Safari:
selector:empty{property:value!important;}用伪类empty再加上!important进行定义的话,目前只有Safari可以识别.
Opera:
@mediaalland(min-width:0px){selector{property:value;}}利用特殊继承法进行定义的话,目前只有Opera可以识别.
以上的Hack并不完整,大家一起补充.
对Hack的运用,最普遍的是CSS盒模型Hack,清除浮动Hack.
CSS盒模型在IE5.X上是有严重解析错误的.这个Hack针对IE5.X:
selctor{width:IE5.X宽度;voice-family:”/”}/””;voice-family:inherit;width:正确宽度;}
清除浮动Hack,相信这个定义用的人很多:
selector:after{content:”.”;display:block;height:0;clear:both;visibility:hidden;}