您现在的位置是:网站首页> 编程资料编程资料
优化浏览器渲染 避免CSS expressions_CSS教程_CSS_网页制作_
2021-09-08
849人已围观
简介 CSS表达式会降低浏览器的渲染性能;用其他方案替换它们将会改善IE浏览器的渲染性能。
概述
CSS表达式会降低浏览器的渲染性能;用其他方案替换它们将会改善IE浏览器的渲染性能。
注意:本节最佳实践只适用于Internet Explorer 5到7,它们支持CSS表达式。Internet Explorer 8放弃使用CSS表达式,而其他浏览器是不支持的。
详细信息
作为一种动态改变文档属性来响应各种事件的的手段,Internet Explorer 5引入了CSS表达式或 “动态属性”。它们由在CSS声明中的CSS属性值里嵌入JavaScript表达式构成。在大多数情况下,它们用于以下目的:
模拟其他浏览器支持但IE浏览器尚未支持的标准CSS属性。
使用比编写全面JavaScript注入式样式更小巧,更便捷的方法,来提供动态样式和高级的事件处理。
不幸的是,CSS表达式对于性能的不良影响是相当大的,因为每当有事件触发,浏览器都要重新计算每个表达式,如一个窗口改变大小,鼠标移动等。CSS表达式的低性能表现是IE 8弃用它们的原因之一。如果你在网页里使用CSS表达式,应该尽一切努力来消除它们并且使用其他方法来达到同样的功能。
建议
尽可能使用标准的CSS属性。
IE 8已高度兼容标准CSS;IE 8只有在“兼容”模式才支持运行CSS表达式,而在“标准”模式下则不支持。如果你不需要向后兼容旧版本的IE,你应该转换成标准的CSS属性来替换所有对应的CSS表达式。如需CSS属性和支持它们的IE版本的完整列表,请参见MSDN的CSS属性索引。如果你确实需要支持所需CSS属性不可用的旧版本IE浏览器,请使用JavaScript来实现等效的功能。
使用JavaScript脚本样式。
如果你正在使用CSS表达式来实现动态样式,用纯JavaScript重写它们是很有意义的,因为这样既能提高IE性能,同时在其他浏览器获得相同效果的支持。在这个由MSDN动态属性页提供的例子里,下面的CSS表达式用于在浏览器里居中一个HTML块元素,并且该元素的尺寸可以在运行时改变,每次调整窗口大小都能重新定位在浏览器中心:
Example DIV
下面是一个使用JavaScript和标准CSS的等价例子:
如果您使用CSS表达式来模拟早期IE版本中不可用的CSS属性,你应该提供版本测试的javascript代码,为支持CSS的浏览器禁止CSS表达式。举例来说,max-width属性,这个属性在一定数量的像素范围内强制文本换行,在IE 7前是不支持的。下面的CSS表达式作为一种解决方法,为IE 5和6提供了这个功能:
p { width: expression( document.body.clientWidth > 600 ? "600px" : "auto" ); }
为不支持此属性的IE浏览器版本使用等价的JavaScript替换CSS表达式,可以使用类似于下面的内容:
相关内容
- IE6/IE7/IE8/Firefox/Chrome/Safari的CSS hack兼容一览表_浏览器兼容教程_CSS_网页制作_
- CSS Hack 汇总快查 振之整理_浏览器兼容教程_CSS_网页制作_
- CSS hack技巧之IE6,IE7,firefox显示不同效果_浏览器兼容教程_CSS_网页制作_
- CSS Position 使用详细小结_CSS教程_CSS_网页制作_
- 编写CSS的一些感悟分享_CSS教程_CSS_网页制作_
- css 条件注释区分非IE浏览器 _CSS教程_CSS_网页制作_
- IE7下当position:fixed遇到text-align:center的解决方法 _CSS教程_CSS_网页制作_
- IE8 css overflow:hidden不起作用_CSS教程_CSS_网页制作_
- css clear之清除区域_CSS教程_CSS_网页制作_
- 区分IE6,IE7,IE8和FF的css hack _浏览器兼容教程_CSS_网页制作_