實測圖片的HTTP請求

請在主流瀏覽器中打開測試頁面,在Fiddler里查看http請求。
1. 隱藏圖片
<img src="1.jpg" style="display: none" />測試:test_1.html
結(jié)論:只有Opera不產(chǎn)生請求。
注意:用visibility: hidden隱藏圖片時,在Opera下也會產(chǎn)生請求。
2. 重復圖片
<img src="1.jpg" /><img src="1.jpg" />測試:test_2.html
結(jié)論:所有瀏覽器都只產(chǎn)生一次請求 。
3. 重復背景
<style type="text/css"> .test1 { background: url(1.jpg) } .test2 { background: url(1.jpg) }</style><div class="test1">test1</div><div class="test2">test2</div>測試:test_3.html
結(jié)論:所有瀏覽器都只產(chǎn)生一次請求。
4. 不存在的元素的背景
<style type="text/css"> .test1 { background: url(1.jpg) } .test2 { background: url(2.jpg) } /* 頁面中沒有class為test2的元素 */</style><div class="test1">test1</div>測試:test_4.html
結(jié)論:背景僅在應用的元素在頁面中存在時,才會產(chǎn)生請求。這對CSS框架來說,很有意義。
5. 隱藏元素的背景
<style type="text/css"> .test1 { background: url(1.jpg); display: none; } .test2 { background: url(2.jpg); visibility: hidden; }</style><div class="test1">test1</div>測試:test_5.html
結(jié)論:Opera和Firefox對于用display: none隱藏的元素背景,不會產(chǎn)生HTTP請求。僅當這些元素非display: none時,才會請求背景圖片。
6. 多重背景
<style type="text/css"> .test1 { background: url(1.jpg); } .test1 { background: url(2.jpg); }</style><div class="test1">test1</div>測試:test_6.html
結(jié)論:除了基于webkit渲染引擎的Safari和Chrome,其它瀏覽器只會請求一張背景圖。
注意:webkit引擎瀏覽器對背景圖都請求,是因為支持CSS3中的多背景圖。
7. hover的背景加載
<style type="text/css"> a.test1 { background: url(1.jpg); } a.test1:hover { background: url(2.jpg); }</style><a href="#" class="test1">test1</a>測試:test_7.html
結(jié)論:觸發(fā)hover時,才會請求hover狀態(tài)下的背景。這會造成閃爍,因此經(jīng)常放在同一張背景圖里通過翻轉(zhuǎn)來實現(xiàn)。
注意:在圖片no-cache的情況下,IE每次hover狀態(tài)改變時,都會產(chǎn)生一次新請求。很糟糕。
2009-05-13晚補充:上面的解釋有誤,更詳細的解釋請參考續(xù)篇。翻轉(zhuǎn)技巧指的是Sprite技術(shù),例子:test_7b.html, 在ie6下不會產(chǎn)生閃爍。
8. JS里innerHTML中的圖片
<script type="text/javascript"> var el = document.createElement('div'); el.innerHTML = '<img src="1.jpg" />'; //document.body.appendChild(el);</script>測試:test_8.html
結(jié)論:只有Opera不會馬上請求圖片。
注意:當添加到DOM樹上時,Opera才會發(fā)送請求。
9. 圖片預加載
最常用的是JS方案:
<script type="text/javascript"> new Image().src = '1.jpg'; new Image().src = '2.jpg';</script>在無JS支持的環(huán)境下,可以采用隱藏元素來預加載:
<img src="1.jpg" style="visibility: hidden; height: 0; width: 0" />測試:test_9.html
終于到總結(jié)了
1.對于隱藏圖片和隱藏元素的背景,Opera不會產(chǎn)生請求。
2.對于隱藏元素的背景,F(xiàn)irefox也不會產(chǎn)生請求。
3.對于尚未插入DOM樹的img元素,Opera不會產(chǎn)生請求。
4.基于webkit引擎的Safari和Chrome,支持多背景圖。
5.其它情景,所有主流瀏覽器保持一致。
對圖片請求的處理上,個人覺得Opera走在前列。
番外
1. 用Fiddler監(jiān)控Opera時,如果是本地服務器,需要在Opera的代理服務器設置里,將本地服務器勾選上。
2. 查看HTTP請求數(shù),還有一個萬無一失的方法是,直接查看Apache的access.log文件。
3. 我的Firefox對于重復圖片和重復背景,會產(chǎn)生重復請求。禁用了所有擴展,問題依舊。有知詳情者,還望告知。
相關(guān)文章
15 個為編程初學者準備的網(wǎng)站(都是國外的一些網(wǎng)站)
今天的文章,我們將分享15個可以學習編程的網(wǎng)站,這些網(wǎng)站上提供了很多編程教程,圖書以及編程練習,希望對你有用2024-11-02- 這篇文章主要介紹了web開發(fā)中的長度單位主要包括px,pt,em等,需要的朋友可以參考下2023-08-06
網(wǎng)頁前端開發(fā)的一些尺寸單位(px,rem單位)
px單位是絕對單位,一般用于pc端網(wǎng)頁開發(fā),因為是絕對單位所以在移動端上的使用體驗并不是很好,rem它是描述相對于當前根元素字體尺寸,是相對單位,它可以根據(jù)根元素的變換而2023-08-06WEB前端優(yōu)化必備js/css壓縮工具YUI-compressor詳解與集成用法
壓縮工具層次不窮,各有優(yōu)點,選擇適合的壓縮工具為將來做項目開發(fā)使用是一件很重要的事情??!在這介紹YUI-compressor,需要的朋友可以參考下2023-06-21- 瀏覽器是多進程的,有瀏覽器主進程,網(wǎng)絡進程,渲染進程,插件進程等,在將html,css,javascript解析成一個頁面的時候,就需要多個進程的分工合作2023-05-01
- 本文為大家整理了常用的文件對應的MIME類型,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-04-25
postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別介紹
這篇文章介紹了postman中form-data、x-www-form-urlencoded、raw、binary的區(qū)別,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-12-28網(wǎng)頁中使用Unicode字符的介紹(&#,\u等)
國際組織制定了可以容納世界上所有文字和符號的字符編碼方案,稱為Unicode,是通用字符集Universal Character Set的縮寫,用以滿足跨語言、跨平臺進行文本轉(zhuǎn)換、處理的要求2021-11-27前端實現(xiàn)字符串GBK與GB2312的編解碼(小結(jié))
這篇文章主要介紹了前端實現(xiàn)字符串GBK與GB2312的編解碼(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2020-12-02- 這篇文章主要介紹了告別硬編碼讓你的前端表格自動計算,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-27