圖片的HTTP請求總結,web圖片http請求匯總,網頁圖片預加載


圖片的http請求,有很多種情況,那么究竟什么情況下面不會發生請求呢?下面我用案例一一列舉一下,希望對你深入了解http圖片請求有所幫助。(請求圖片截圖,均已谷歌瀏覽器為例!文章轉載請聯系我,或者注明haorooms博客並附鏈接地址!)

1. 隱藏圖片

<img src="haorooms.jpg" style="display: none" />

http請求如下:

enter image description here

結論:只有Opera不產生請求。 注意:用visibility: hidden隱藏圖片時,在Opera下也會產生請求。

2. 重復圖片

<img src="haorooms.jpg" /> <img src="haorooms.jpg" />

http請求如下:

enter image description here

結論:所有瀏覽器都只產生一次請求 。

3. 重復背景

<style type="text/css"> .test1 { background: url(haorooms.jpg) } .test2 { background: url(haorooms.jpg) } </style> <div class="test1">test1</div> <div class="test2">test2</div>

http請求如下:

enter image description here

結論:所有瀏覽器都只產生一次請求。

4. 不存在的元素的背景

<style type="text/css"> .test1 { background: url(haorooms.jpg) } .test2 { background: url(http2.jpg) } /* 頁面中沒有class為test2的元素 */ </style> <div class="test1">test1</div>

http請求如下:

enter image description here

結論:背景僅在應用的元素在頁面中存在時,才會產生請求。這對CSS框架來說,很有意義。

5. 隱藏元素的背景

<style type="text/css"> .test1 { background: url(haorooms.jpg); display: none; } .test2 { background: url(http2.jpg); visibility: hidden; } </style> <div class="test1">test1</div>

http請求如下:

enter image description here

結論:Opera和Firefox對於用display: none隱藏的元素背景,不會產生HTTP請求。僅當這些元素非display: none時,才會請求背景圖片。

6. 多重背景

<style type="text/css"> .test1 { background: url(haorooms.jpg); } .test1 { background: url(http2.jpg); } </style> <div class="test1">test1</div>

上面這段代碼的http請求,只會請求http2.jpg這一張圖片,原因是test1的class把上面的給覆蓋掉了,所有只請求后面的一張圖片!

假如用css3多張背景圖片的寫法:

<style type="text/css"> .test1 { background-image:url("haorooms.jpg"),url("http2.jpg"); } </style> <div class="test1">test1</div>

那么http請求如下:

enter image description here

webkit引擎瀏覽器對背景圖都請求,是因為支持CSS3中的多背景圖。關於css3多張背景圖片,我前面寫了一篇文章介紹,請看:http://www.haorooms.com/post/css3_bg_multi

7. hover的背景加載

<style type="text/css"> a.test1 { background: url(haorooms.jpg); } a.test1:hover { background: url(http2.jpg); } </style> <a href="#" class="test1">test1</a>

http請求如下:

enter image description here

結論:觸發hover時,才會請求hover狀態下的背景。不觸發的話,只請求默認的背景圖片。

8. JS里innerHTML中的圖片

<script type="text/javascript"> var el = document.createElement('div'); el.innerHTML = '<img src="haorooms.jpg" />'; //document.body.appendChild(el); </script>

http請求如下:

enter image description here

結論:只有Opera不會馬上請求圖片。

注意:當添加到DOM樹上時,Opera才會發送請求。

9. 圖片預加載

最常用的是JS方案:

<script type="text/javascript"> new Image().src = 'haorooms.jpg'; new Image().src = 'http2.jpg'; </script>

在無JS支持的環境下,可以采用隱藏元素來預加載:

<img src="haoroomscom.jpg" style="visibility: hidden; height: 0; width: 0" />

總結

1、對於隱藏圖片和隱藏元素的背景,Opera不會產生請求。

2、對於隱藏元素的背景,Firefox也不會產生請求。

3、對於尚未插入DOM樹的img元素,Opera不會產生請求。

4、基於webkit引擎的Safari和Chrome,支持多背景圖。

5、其它情景,所有主流瀏覽器保持一致。

希望上面的圖片http請求對您有所幫助,大家可以相互留言交流!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM