IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類|軟件專題|手機版|論壇轉(zhuǎn)貼|軟件發(fā)布

您當(dāng)前所在位置: 首頁網(wǎng)絡(luò)編程DIVCSS → 背景圖片設(shè)置對CSS渲染效率的研究

背景圖片設(shè)置對CSS渲染效率的研究

時間:2015-06-28 00:00:00 來源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評論(0)

這篇文章主要講了CSS對背景圖片渲染效率的一些經(jīng)驗和研究:

書寫高效的CSS - 漫談CSS的渲染效率http://www.52css.com/article.asp?id=787

CSS對Web頁面載入效率的影響http://www.52css.com/article.asp?id=751

樹型結(jié)構(gòu)豎線用樣式表(背景圖)來實現(xiàn),樣式表背景圖片只需要加載一次,而現(xiàn)在這個模式(用多個)圖片雖然有緩存機制,但還是有可以每張小圖片都請求一次服務(wù)器的,所以我想用樣式表來實現(xiàn)有多么的好呀,代碼又精簡,結(jié)構(gòu)又清晰,效果又酷,但是結(jié)果我將近一個星期的測試,我這種設(shè)想徹底失敗,原因就是樣式表的渲染效率太差。新的構(gòu)想沒能實現(xiàn),心情有些沮喪,但我想也應(yīng)該讓大家分享一下這個測試成果。

這里我再解釋一下樹型里的豎線,樹的左邊都有 ┌ ├ └ │ 這些豎線圖表示樹層次,我的1.0版里是用一張張的小圖片堆積起來的,而這種使用樣式表的是用

(l是字母L)這種代碼來實現(xiàn)的,樣式表負責(zé)填充背景圖。

?

以下為引用的內(nèi)容:
??? Example Source Code [www.52css.com]
??? #www_52css_com .l0{background:url(line0.gif) no-repeat center}
??? #www_52css_com .l1{background:url(line1.gif) no-repeat center}
??? #www_52css_com .l2{background:url(line2.gif) no-repeat center}
??? #www_52css_com .l3{background:url(line3.gif) no-repeat center}
??? #www_52css_com .l4{background:url(line4.gif) no-repeat center}
??? #www_52css_com .ll{background:url(line5.gif) no-repeat center}
??? #www_52css_com .pm0{background:url(plus0.gif) no-repeat center}
??? #www_52css_com .pm1{background:url(plus1.gif) no-repeat center}
??? #www_52css_com .pm2{background:url(plus2.gif) no-repeat center}
??? #www_52css_com .pm3{background:url(plus3.gif) no-repeat center}
??? #www_52css_com .expand .pm0{background:url(minus0.gif) no-repeat center}
??? #www_52css_com .expand .pm1{background:url(minus1.gif) no-repeat center}
??? #www_52css_com .expand .pm2{background:url(minus2.gif) no-repeat center}
??? #www_52css_com .expand .pm3{background:url(minus3.gif) no-repeat center}

上面這段CSS是我在腳本里動態(tài)生成的一段樣式的片段,我把它貼上來,有助于后面的講解。運用樣式表之后,果真精簡了許多,每個節(jié)點的生成也夠快,但我發(fā)現(xiàn),當(dāng)我的樹節(jié)點量達到,比如說300-500個節(jié)點之后,節(jié)點生成的效率沒有影響什么,但每個節(jié)點的展開/收縮很慢很慢,需要幾秒鐘以上甚至10秒,且這個期間的CPU占用率是100%。說明一下,樹型的展開/收縮是設(shè)置父節(jié)點的 style.display = none|block 來實現(xiàn)的。我的電腦配置是:AMD2800+ 1GDDR400內(nèi)存,配置不太差的。

我首先的反應(yīng)是:是不是用了太多的

影響了效率?因為我每一個節(jié)點都用了一個
,但是我把
換成了
等,效率沒有什么改善,說明這個CPU占用率100%的問題不是HTML標(biāo)簽的問題,那么剩下來的問題就是這里使用了樣式表。

以一個500節(jié)點的量來說吧,1.0里左邊大概要堆積2000個左右的小圖片。這種情況在瀏覽器端設(shè)置本地不緩存的時候會存在很大的問題,要加載這些多的小圖片需要消耗不少的時間和服務(wù)器資源,所以我才會有這種新的用樣式表來解決的想法,現(xiàn)在換成樣式表法,也就是大概有2000個地方需要用樣式表來渲染出背景圖。我測試了各種情況,再對比1.0版的代碼得出的結(jié)論是:CPU的點用率如此之高,唯一的原因也就只有這種渲染的耗時了。驗證也非常簡單,我把上面的樣式表的左邊 #www_52css_com 這部分去掉,也就是去掉樣式表的依托關(guān)系,測試的結(jié)果發(fā)現(xiàn)效率改善了很多,但耗時依然是可觀的,有3-5秒之多。

另外我換了不同的瀏覽器,測試的結(jié)果也不太一樣,在IE里最為惡心,比如說我在某個節(jié)點有500子節(jié)點,我將它收起(CPU100%,等待3-5秒),也就是display="none",這時候若我去收起這個節(jié)點的父節(jié)點(這個節(jié)點沒有其它的同級節(jié)點,即它的父節(jié)點只有它這么一個子節(jié)點),照理說只有一個節(jié)點,收起應(yīng)該是即時的事,但結(jié)果不然,結(jié)果又是3-5秒的CPU100%,這個讓我狂郁悶,也就是說即使HTML對象被display="none"隱藏掉了,但是對它的父級進行任何操作的時候,IE會對這些被隱藏的對象用樣式表重新渲染一遍,真是搞不懂IE的開發(fā)者當(dāng)初是怎么想的。

我又到FIREFOX里測試了一下,在收起的時候(display=none)是瞬間的,可以肯定,F(xiàn)F對待被隱藏的對象不會再消耗精力。當(dāng)然展開的時候所有的瀏覽器都一樣:3-5秒的CPU100%,不過FF稍微要快些。

通過上面的這些現(xiàn)象我得出這么一個結(jié)論:樣式表在動態(tài)渲染的時候效率并不高;在父容器發(fā)現(xiàn)狀態(tài)變化的時候會引起它的所以子孫對象的樣式表重新渲染;FireFox 對待被display=none隱藏的對象不會重新渲染而IE會。

那么這種樣式表的渲染效率問題以前為什么一直沒有被發(fā)現(xiàn)呢?嘿嘿,大家做網(wǎng)頁的時候難得會做到這種極端的時候,一個頁面里有幾千個需要樣式表渲染背景圖。通常也就幾個地方或者幾十個地方了,所以感覺不出來渲染的效率,也感覺不出這方面在不同的瀏覽器之間的差別。但是在做樹這些的控件的時候必定會碰到各種極端的問題,比如大數(shù)據(jù)量的數(shù)組,生成的HTML對象的多少等等,象這種渲染的效率差別也只是我在寫JS腳本時碰到的問題之一而已。今天我把這個測試結(jié)果共享出來是希望對大家以后寫程序的時候有所借薦,在做設(shè)計的時候有所考慮。

關(guān)鍵詞標(biāo)簽:效率,研究,圖片,設(shè)置,

相關(guān)閱讀

文章評論
發(fā)表評論

熱門文章 DIV+CSS網(wǎng)頁布局常用的一些基礎(chǔ)知識整理 DIV+CSS網(wǎng)頁布局常用的一些基礎(chǔ)知識整理 完美解決CSS網(wǎng)頁水平居中 完美解決CSS網(wǎng)頁水平居中 XHTML+CSS兼容解決方案 XHTML+CSS兼容解決方案 CSS網(wǎng)頁布局困擾新手的八個問題 CSS網(wǎng)頁布局困擾新手的八個問題

相關(guān)下載

    人氣排行 DIV CSS完美兼容IE6/IE7/FF的通用方法 CSS實例:list-style-type在IE與FF中奇怪的現(xiàn)象解析-CSS布局實例 CSS實例:通過定義漸變邊框給圖片加陰影 CSS常用技巧之一 禁止文字自動換行 網(wǎng)頁頁面設(shè)計中CSS十大注意 解決用CSS控制DIV居中失效的問題 css div設(shè)置float后高度不能自動增加 讓CSS兼容IE和Firefox的技巧集合