时间:2021-05-08
概述
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>声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
书写顺序的意义减少浏览器reflow(回流),提升浏览器渲染dom的性能①:解析html构建dom树,解析css构建css树:将html解析成树形的数据结构,将
will-change通过告知浏览器该元素会有哪些变化,使浏览器提前做好优化准备,增强页面渲染性能。属性的取值:1、auto:实行标准浏览器优化。2、scrol
怎样尽可能的缩短浏览器上页面渲染的时间,文章从以下几方面着手:写出高效的css代码避免使用css表达式把css文件放在页面顶部指定页面图片的尺寸页面头部标明文档
CSS3更有效优化页面性能及更节省开发成本。虽然说浏览器执行JS是单线程执行,浏览器通过主线程与合成线程协同工作的方式来渲染和编译每一个页面。通常运行JavaS
一、浏览器渲染过程1、用户打开页面,空白屏,等待html的返回2、html下载完毕,开始解析html,初始渲染3、下载css、js等资源,执行js渲染虚拟DOM