首页 > 开发 > CSS > 正文

优化浏览器渲染:避免CSS expressions

2024-07-11 09:03:00
字体:
来源:转载
供稿:网友

武林网(www.vevb.com)文章简介: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块元素,并且该元素的尺寸可以在运行时改变,每次调整窗口大小都能重新定位在浏览器中心:

<div id="oDiv" style="background-color: #CFCFCF; position: absolute;left:expression(document.body.clientWidth/2-oDiv.offsetWidth/2);top:expression(document.body.clientHeight/2-oDiv.offsetHeight/2)">Example DIV</div>

下面是一个使用JavaScript和标准CSS的等价例子:

<style>  #oDiv { position: absolute; background-color: #CFCFCF;}</style><script type="text/javascript"> // Check for browser support of event handling capability  if (window.addEventListener) {  window.addEventListener("load", centerDiv, false); window.addEventListener("resize", centerDiv, false);  } else if (window.attachEvent) {  window.attachEvent("onload", centerDiv);  window.attachEvent("onresize", centerDiv);  } else {  window.onload = centerDiv;  window.resize = centerDiv;  }  function centerDiv() {  var myDiv = document.getElementById("oDiv");  var myBody = document.body;  var bodyWidth = myBody.offsetWidth;  //Needed for Firefox, which doesn't support offsetHeight  var bodyHeight; if (myBody.scrollHeight) bodyHeight = myBody.scrollHeight; else bodyHeight = myBody.offsetHeight;  var divWidth = myDiv.offsetWidth;  if (myDiv.scrollHeight)   var divHeight = myDiv.scrollHeight;   else var divHeight = myDiv.offsetHeight;myDiv.style.top = (bodyHeight - divHeight) / 2;  myDiv.style.left = (bodyWidth - divWidth) / 2;  }</script>

如果您使用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表达式,可以使用类似于下面的内容:

<style>  p { max-width: 300px; }</style><script type="text/javascript">  if ((navigator.appName == "Microsoft Internet Explorer") && (parseInt(navigator.appVersion) < 7))  window.attachEvent("onresize", setMaxWidth);  function setMaxWidth() {  var paragraphs = document.getElementsByTagName("p");  for ( var i = 0; i < paragraphs.length; i++ )  paragraphs[i].style.width = ( document.body.clientWidth > 300 ? "300px" : "auto" );</script>

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表