优化赏识器渲染:停止CSS expressions
发布时间:2018-09-03 22:30:27 所属栏目:创业 来源:站长网
导读:概述 CSS表达式会低落赏识器的渲染机能;用其他方案替代它们将会改进 IE赏识器 的渲染机能。 留意:本节最佳实践只合用于Internet Explorer 5到7,它们支持CSS表达式。Internet Explorer 8放弃行使CSS表达式,而其他赏识器是不支持的。 具体信息 作为一种动
概述 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> (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |