原文:http://www.zishu.cn/blogview.asp?logID=773
最近很少寫CSS了,以后也可能寫的會很少了,所以還是想把自已的一些經驗能和大家分享一下,希望能給大家一些幫助!
這篇文章主要寫的提高網頁在客戶端瀏覽器的渲染速度的CSS部分,暫時總結了10條。
1、*{} #zishu *{} 盡量避開
由于不同瀏覽器對HTML標簽的解釋有差異,所以最終的網頁效果在不同的瀏覽器中可能是不一樣的,為了消除這方面的風險,設計者通常會在CSS的一個始就把所有標簽的默認屬性全部去除,以達到所有簽標屬性值都統一的效果。所以就有了*通配符。*會遍歷所有的標簽;
*{margin:0; padding:0}
如果這樣寫,頁面中所有的標簽的margin全是0;padding也是0;
#zishu *{margin:0; padding:0}
如果這樣寫,在id等于zishu下邊的所有標簽的margin全是0;padding也是0;
這樣寫的問題是:
建議的的解決辦法:
2、濾鏡的一些東西不要去用
IE的一些濾鏡在FIREFOX中不支持,往往寫一些效果時你還是使用CSS HACK;而濾鏡是一個非常毫資源的東西;特別是一些羽化、陰影和一個前透明的效果;
例如一個陰影效果:
運行代碼框
例子的鏈接為:http://www.zishu.cn/blogview.asp?logID=610
百姓網的登陸部分使用了陰影效果:http://shanghai.baixing.com/wo/denglu
建議的解決辦法:
一個非常好的例子,就是在今年512大地震時,很多網站一夜之間全部變成了灰色,他們只用了一行CSS代碼:
body{filter: gray;}
但,你會看會看到這些網頁非常的慢,打開后你的CPU也會飆升,不夸張的說,如果你的電腦配置差,干死你也不為過。
3、一個頁面上少用絕對定位
絕對定位(position:absolute )是網頁布局中很常用到的,特別是作一些浮動效果時,也會讓頁面看起來非常的酷。但網頁中如果使用過多的絕對定位,會讓你的網頁變得非常的慢,這一點上邊FIREFOX表現要比IE還要差。
例如:
<style>li{ position:absolute;}</style>
<ul>
<li style="left:10px; top:20px">001</li>
<li style="left:30px; top:70px">001</li>
<li style="left:40px; top:50px">001</li>
……
</ul>
建議的解決辦法:
下一篇 CSS 使圖片變灰的實例