欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

實(shí)測(cè)圖片的HTTP請(qǐng)求

  發(fā)布時(shí)間:2013-10-14 15:57:32   作者:佚名   我要評(píng)論
對(duì)于隱藏圖片和隱藏元素的背景,Opera不會(huì)產(chǎn)生請(qǐng)求;對(duì)于隱藏元素的背景,F(xiàn)irefox也不會(huì)產(chǎn)生請(qǐng)求,對(duì)圖片請(qǐng)求的處理上,個(gè)人覺(jué)得Opera走在前列,感興趣的朋友可以了解下本文

請(qǐng)?jiān)谥髁鳛g覽器中打開(kāi)測(cè)試頁(yè)面,在Fiddler里查看http請(qǐng)求。

1. 隱藏圖片
<img src="1.jpg" style="display: none" />測(cè)試:test_1.html
結(jié)論:只有Opera不產(chǎn)生請(qǐng)求。
注意:用visibility: hidden隱藏圖片時(shí),在Opera下也會(huì)產(chǎn)生請(qǐng)求。

2. 重復(fù)圖片
<img src="1.jpg" /><img src="1.jpg" />測(cè)試:test_2.html
結(jié)論:所有瀏覽器都只產(chǎn)生一次請(qǐng)求 。

3. 重復(fù)背景
<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>測(cè)試:test_3.html
結(jié)論:所有瀏覽器都只產(chǎn)生一次請(qǐng)求。

4. 不存在的元素的背景
<style type="text/css">    .test1 { background: url(1.jpg) }    .test2 { background: url(2.jpg) } /* 頁(yè)面中沒(méi)有class為test2的元素 */</style><div class="test1">test1</div>測(cè)試:test_4.html
結(jié)論:背景僅在應(yīng)用的元素在頁(yè)面中存在時(shí),才會(huì)產(chǎn)生請(qǐng)求。這對(duì)CSS框架來(lái)說(shuō),很有意義。

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>測(cè)試:test_5.html
結(jié)論:Opera和Firefox對(duì)于用display: none隱藏的元素背景,不會(huì)產(chǎn)生HTTP請(qǐng)求。僅當(dāng)這些元素非display: none時(shí),才會(huì)請(qǐng)求背景圖片。

6. 多重背景
<style type="text/css">    .test1 { background: url(1.jpg); }    .test1 { background: url(2.jpg); }</style><div class="test1">test1</div>測(cè)試:test_6.html
結(jié)論:除了基于webkit渲染引擎的Safari和Chrome,其它瀏覽器只會(huì)請(qǐng)求一張背景圖。
注意:webkit引擎瀏覽器對(duì)背景圖都請(qǐng)求,是因?yàn)橹С諧SS3中的多背景圖。

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>測(cè)試:test_7.html
結(jié)論:觸發(fā)hover時(shí),才會(huì)請(qǐng)求hover狀態(tài)下的背景。這會(huì)造成閃爍,因此經(jīng)常放在同一張背景圖里通過(guò)翻轉(zhuǎn)來(lái)實(shí)現(xiàn)。
注意:在圖片no-cache的情況下,IE每次hover狀態(tài)改變時(shí),都會(huì)產(chǎn)生一次新請(qǐng)求。很糟糕。
2009-05-13晚補(bǔ)充:上面的解釋有誤,更詳細(xì)的解釋請(qǐng)參考續(xù)篇。翻轉(zhuǎn)技巧指的是Sprite技術(shù),例子:test_7b.html, 在ie6下不會(huì)產(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>測(cè)試:test_8.html
結(jié)論:只有Opera不會(huì)馬上請(qǐng)求圖片。
注意:當(dāng)添加到DOM樹(shù)上時(shí),Opera才會(huì)發(fā)送請(qǐng)求。

9. 圖片預(yù)加載
最常用的是JS方案:

復(fù)制代碼
代碼如下:

<script type="text/javascript"> new Image().src = '1.jpg'; new Image().src = '2.jpg';</script>在無(wú)JS支持的環(huán)境下,可以采用隱藏元素來(lái)預(yù)加載:
<img src="1.jpg" style="visibility: hidden; height: 0; width: 0" />測(cè)試:test_9.html

終于到總結(jié)了

1.對(duì)于隱藏圖片和隱藏元素的背景,Opera不會(huì)產(chǎn)生請(qǐng)求。
2.對(duì)于隱藏元素的背景,F(xiàn)irefox也不會(huì)產(chǎn)生請(qǐng)求。
3.對(duì)于尚未插入DOM樹(shù)的img元素,Opera不會(huì)產(chǎn)生請(qǐng)求。
4.基于webkit引擎的Safari和Chrome,支持多背景圖。
5.其它情景,所有主流瀏覽器保持一致。
對(duì)圖片請(qǐng)求的處理上,個(gè)人覺(jué)得Opera走在前列。

番外

1. 用Fiddler監(jiān)控Opera時(shí),如果是本地服務(wù)器,需要在Opera的代理服務(wù)器設(shè)置里,將本地服務(wù)器勾選上。

2. 查看HTTP請(qǐng)求數(shù),還有一個(gè)萬(wàn)無(wú)一失的方法是,直接查看Apache的access.log文件。

3. 我的Firefox對(duì)于重復(fù)圖片和重復(fù)背景,會(huì)產(chǎn)生重復(fù)請(qǐng)求。禁用了所有擴(kuò)展,問(wèn)題依舊。有知詳情者,還望告知。

相關(guān)文章

最新評(píng)論