多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > web前端 > htmlcss > 優化瀏覽器渲染:避免CSS expressions

優化瀏覽器渲染:避免CSS expressions

來源:程序員人生   發布時間:2013-10-17 08:52:29 閱讀次數:3334次
概述

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>
生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 欧美成人性色大片在线观看 | 国产视频a区 | 久久精品国产99久久6动漫欧 | 麻豆69堂免费视频 | 69免费视频大片 | 久久不射网 | 亚洲www| 欧美男同志高清videosbest | 国产成人一区二区在线不卡 | 一级黄色淫片 | 亚洲春色图片 | a毛片免费播放全部完整 | 久久影视免费观看网址 | 高清在线亚洲精品国产二区 | h国产在线| 亚洲一区二区三区高清网 | 五月天婷婷在线视频国产在线 | 美国一级毛片片aa成人 | 国产性生活 | 国内精品久久久久影院老司 | 精品乱人伦一区二区 | 在线爱爱| 久久国产精品影院 | 日韩三级免费 | 亚洲黄色大全 | 久久在线一区 | 在线观看国产小视频 | 尤物网址在线观看日本 | 日韩一区国产二区欧美三区 | 尤物视频在线观看视频 | 欧美亚洲福利 | 最近中文字幕完整视频大全版 | 亚洲三级黄色片 | 一级特黄特色aa大片 | 花蝴蝶亚洲一区二区三区 | 国产成人精品免费久久久久 | 91伊人久久大香线蕉 | 久久精品国产精品亚洲精品 | 奇奇影院理论片在线观看 | 91麻豆精品国产综合久久久 | www.免费观看 |