加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > 正文

优化赏识器渲染:停止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>

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读