網(wǎng)頁(yè)CSS背景圖片使用的測(cè)試結(jié)果
互聯(lián)網(wǎng) 發(fā)布時(shí)間:2008-10-17 19:26:15 作者:佚名
我要評(píng)論

這篇文章主要講了CSS對(duì)背景圖片渲染效率的一些經(jīng)驗(yàn)和研究,在webjx.com中,還有著類似CSS效率的相關(guān)文章。
樹型結(jié)構(gòu)豎線用樣式表(背景圖)來(lái)實(shí)現(xiàn),樣式表背景圖片只需要加載一次,而現(xiàn)在這個(gè)模式(用多個(gè)<img>)圖片雖然有緩存機(jī)制,但還是有可以每張小圖
這篇文章主要講了CSS對(duì)背景圖片渲染效率的一些經(jīng)驗(yàn)和研究,在jb51.net中,還有著類似CSS效率的相關(guān)文章。
樹型結(jié)構(gòu)豎線用樣式表(背景圖)來(lái)實(shí)現(xiàn),樣式表背景圖片只需要加載一次,而現(xiàn)在這個(gè)模式(用多個(gè)<img>)圖片雖然有緩存機(jī)制,但還是有可以每張小圖片都請(qǐng)求一次服務(wù)器的,所以我想用樣式表來(lái)實(shí)現(xiàn)有多么的好呀,代碼又精簡(jiǎn),結(jié)構(gòu)又清晰,效果又酷,但是結(jié)果我將近一個(gè)星期的測(cè)試,我這種設(shè)想徹底失敗,原因就是樣式表的渲染效率太差。新的構(gòu)想沒能實(shí)現(xiàn),心情有些沮喪,但我想也應(yīng)該讓大家分享一下這個(gè)測(cè)試成果。
這里我再解釋一下樹型里的豎線,樹的左邊都有 ┌ ├ └ │ 這些豎線圖表示樹層次,我的1.0版里是用一張張的小圖片堆積起來(lái)的,而這種使用樣式表的是用<div class="l2"></div> (l是字母L)這種代碼來(lái)實(shí)現(xiàn)的,樣式表負(fù)責(zé)填充背景圖。
#www_jb51_com .l0{background:url(line0.gif) no-repeat center}
#www_jb51_com .l1{background:url(line1.gif) no-repeat center}
#www_jb51_com .l2{background:url(line2.gif) no-repeat center}
#www_jb51_com .l3{background:url(line3.gif) no-repeat center}
#www_jb51_com .l4{background:url(line4.gif) no-repeat center}
#www_jb51_com .ll{background:url(line5.gif) no-repeat center}
#www_jb51_com .pm0{background:url(plus0.gif) no-repeat center}
#www_jb51_com .pm1{background:url(plus1.gif) no-repeat center}
#www_jb51_com .pm2{background:url(plus2.gif) no-repeat center}
#www_jb51_com .pm3{background:url(plus3.gif) no-repeat center}
#www_jb51_com .expand .pm0{background:url(minus0.gif) no-repeat center}
#www_jb51_com .expand .pm1{background:url(minus1.gif) no-repeat center}
#www_jb51_com .expand .pm2{background:url(minus2.gif) no-repeat center}
#www_jb51_com .expand .pm3{background:url(minus3.gif) no-repeat center}
上面這段CSS是我在腳本里動(dòng)態(tài)生成的一段樣式的片段,我把它貼上來(lái),有助于后面的講解。運(yùn)用樣式表之后,果真精簡(jiǎn)了許多,每個(gè)節(jié)點(diǎn)的生成也夠快,但我發(fā)現(xiàn),當(dāng)我的樹節(jié)點(diǎn)量達(dá)到,比如說(shuō)300-500個(gè)節(jié)點(diǎn)之后,節(jié)點(diǎn)生成的效率沒有影響什么,但每個(gè)節(jié)點(diǎn)的展開/收縮很慢很慢,需要幾秒鐘以上甚至10秒,且這個(gè)期間的CPU占用率是100%。說(shuō)明一下,樹型的展開/收縮是設(shè)置父節(jié)點(diǎn)的 style.display = none|block 來(lái)實(shí)現(xiàn)的。我的電腦配置是:AMD2800 1GDDR400內(nèi)存,配置不太差的。
我首先的反應(yīng)是:是不是用了太多的<table>影響了效率?因?yàn)槲颐恳粋€(gè)節(jié)點(diǎn)都用了一個(gè)<table>,但是我把<table>換成了<div>、<span>等,效率沒有什么改善,說(shuō)明這個(gè)CPU占用率100%的問題不是HTML標(biāo)簽的問題,那么剩下來(lái)的問題就是這里使用了樣式表。
以一個(gè)500節(jié)點(diǎn)的量來(lái)說(shuō)吧,1.0里左邊大概要堆積2000個(gè)左右的小圖片。這種情況在瀏覽器端設(shè)置本地不緩存的時(shí)候會(huì)存在很大的問題,要加載這些多的小圖片需要消耗不少的時(shí)間和服務(wù)器資源,所以我才會(huì)有這種新的用樣式表來(lái)解決的想法,現(xiàn)在換成樣式表法,也就是大概有2000個(gè)地方需要用樣式表來(lái)渲染出背景圖。我測(cè)試了各種情況,再對(duì)比1.0版的代碼得出的結(jié)論是:CPU的點(diǎn)用率如此之高,唯一的原因也就只有這種渲染的耗時(shí)了。驗(yàn)證也非常簡(jiǎn)單,我把上面的樣式表的左邊 #www_jb51_com 這部分去掉,也就是去掉樣式表的依托關(guān)系,測(cè)試的結(jié)果發(fā)現(xiàn)效率改善了很多,但耗時(shí)依然是可觀的,有3-5秒之多。
另外我換了不同的瀏覽器,測(cè)試的結(jié)果也不太一樣,在IE里最為惡心,比如說(shuō)我在某個(gè)節(jié)點(diǎn)有500子節(jié)點(diǎn),我將它收起(CPU100%,等待3-5秒),也就是display="none",這時(shí)候若我去收起這個(gè)節(jié)點(diǎn)的父節(jié)點(diǎn)(這個(gè)節(jié)點(diǎn)沒有其它的同級(jí)節(jié)點(diǎn),即它的父節(jié)點(diǎn)只有它這么一個(gè)子節(jié)點(diǎn)),照理說(shuō)只有一個(gè)節(jié)點(diǎn),收起應(yīng)該是即時(shí)的事,但結(jié)果不然,結(jié)果又是3-5秒的CPU100%,這個(gè)讓我狂郁悶,也就是說(shuō)即使HTML對(duì)象被display="none"隱藏掉了,但是對(duì)它的父級(jí)進(jìn)行任何操作的時(shí)候,IE會(huì)對(duì)這些被隱藏的對(duì)象用樣式表重新渲染一遍,真是搞不懂IE的開發(fā)者當(dāng)初是怎么想的。
我又到FIREFOX里測(cè)試了一下,在收起的時(shí)候(display=none)是瞬間的,可以肯定,F(xiàn)F對(duì)待被隱藏的對(duì)象不會(huì)再消耗精力。當(dāng)然展開的時(shí)候所有的瀏覽器都一樣:3-5秒的CPU100%,不過FF稍微要快些。
通過上面的這些現(xiàn)象我得出這么一個(gè)結(jié)論:樣式表在動(dòng)態(tài)渲染的時(shí)候效率并不高;在父容器發(fā)現(xiàn)狀態(tài)變化的時(shí)候會(huì)引起它的所以子孫對(duì)象的樣式表重新渲染;FireFox 對(duì)待被display=none隱藏的對(duì)象不會(huì)重新渲染而IE會(huì)。
那么這種樣式表的渲染效率問題以前為什么一直沒有被發(fā)現(xiàn)呢?嘿嘿,大家做網(wǎng)頁(yè)的時(shí)候難得會(huì)做到這種極端的時(shí)候,一個(gè)頁(yè)面里有幾千個(gè)需要樣式表渲染背景圖。通常也就幾個(gè)地方或者幾十個(gè)地方了,所以感覺不出來(lái)渲染的效率,也感覺不出這方面在不同的瀏覽器之間的差別。但是在做樹這些的控件的時(shí)候必定會(huì)碰到各種極端的問題,比如大數(shù)據(jù)量的數(shù)組,生成的HTML對(duì)象的多少等等,象這種渲染的效率差別也只是我在寫JS腳本時(shí)碰到的問題之一而已。今天我把這個(gè)測(cè)試結(jié)果共享出來(lái)是希望對(duì)大家以后寫程序的時(shí)候有所借薦,在做設(shè)計(jì)的時(shí)候有所考慮。
相關(guān)文章
css背景圖片的背景裁切、背景透明度、背景變換等效果運(yùn)用
大家都知道,目前有很多瀏覽器無(wú)法實(shí)現(xiàn)背景裁切、背景透明度、背景變換和復(fù)雜背景定位等效果;那么這篇文章將詳細(xì)介紹了這幾種背景圖片的處理方法,需要了解的朋友可以參考下2012-12-24- IE6下CSS背景圖片閃爍的Bug(ie6下的背景圖片緩存問題)2011-07-27
鏈接偽類(:hover)CSS背景圖片有閃動(dòng)BUG的解決方法
IE6下鏈接偽類(:hover)CSS背景圖片有閃動(dòng)BUG,主要原因ie會(huì)再一次請(qǐng)求這張圖片,或者說(shuō)圖片沒被緩存。2011-04-28css利用一張背景圖制作導(dǎo)航菜單實(shí)現(xiàn)思路及代碼
利用一張背景圖片來(lái)實(shí)現(xiàn)菜單的懸停狀態(tài),沒有什么不可思議完全可以辦得到,僅這一張圖片,我們實(shí)現(xiàn)一個(gè)橫行CSS菜單。并設(shè)置它們的懸停效果,感興趣的朋友可以參考下哈,希2013-03-28純css實(shí)現(xiàn)的六邊形(蜂窩)導(dǎo)航效果(支持hover/兼容瀏覽器)
在之前的文章中曾經(jīng)寫到過一篇“三角形變形記之純css實(shí)現(xiàn)的分布導(dǎo)航條效果”,其中用到了邊框?qū)崿F(xiàn)三角形的效果。最近又折騰了一個(gè)六邊形的蜂窩效果給大家蹂躪。主要用到了2013-02-057款設(shè)計(jì)巧妙的css3飄帶狀3D立體效果的導(dǎo)航菜單和表單窗口
接下來(lái)向大家推薦7款設(shè)計(jì)巧妙的CSS3飄帶狀菜單和窗口,相當(dāng)不錯(cuò)的效果,很多都具有3D立體效果,看了相信你一定會(huì)喜歡的好了不多說(shuō),切入主題,希望本文可以幫助到你,提高2013-02-04不規(guī)則背景墻 CSS實(shí)現(xiàn)背景圖片不規(guī)則的導(dǎo)航菜單
一般情況下導(dǎo)航菜單的背景圖片都是比較有規(guī)則的,但是平時(shí)我們也會(huì)遇到很多背景圖片形狀不規(guī)則導(dǎo)航條比如但鼠標(biāo)移上的時(shí)候,背景圖片不規(guī)則,本例只討論此種類型2013-01-02CSS3等相關(guān)屬性制作分頁(yè)導(dǎo)航實(shí)現(xiàn)代碼
W3cplus第二版本剛上線時(shí),好多位朋友向我問起站上的分頁(yè)導(dǎo)航樣式是怎么制作;為了報(bào)答各位朋友一持對(duì)本站的大力支持,今天我特意把這個(gè)分頁(yè)導(dǎo)航的效果當(dāng)作一個(gè)小教程來(lái)說(shuō)。2012-12-24- 不改變html結(jié)構(gòu),使導(dǎo)航菜單垂直水平居中這個(gè)問題應(yīng)該如何解決呢?本文將詳細(xì)介紹,需要了解的朋友可以參考下2012-11-30
純CSS打造Bubble氣泡提示框?qū)崿F(xiàn)代碼
要做一個(gè)Bubble氣泡提示框,如果用CSS3特性來(lái)做很容易,用圖片來(lái)做也可以,但前者有兼容性問題,后者又不夠靈活,用圖片做有一個(gè)例子可以看看jquery打造一款側(cè)邊彈出的垂直2011-11-23