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

CSS控制前端圖片HTTP請(qǐng)求的各種情況示例

haorooms   發(fā)布時(shí)間:2016-06-16 10:55:36   作者:Aaron   我要評(píng)論
Web前端圖片加載的方式多種多樣,其所產(chǎn)生的HTTP請(qǐng)求也各異,這里我們就來(lái)列舉CSS控制前端圖片HTTP請(qǐng)求的各種情況示例,需要的朋友可以參考下

圖片的http請(qǐng)求,有很多種情況,那么究竟什么情況下面不會(huì)發(fā)生請(qǐng)求呢?下面我用案例一一列舉一下,希望對(duì)你深入了解http圖片請(qǐng)求有所幫助。

1. 隱藏圖片

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <img src="haorooms.jpg" style="display: none" />  

http請(qǐng)求如下:
2016616105558967.jpg (1067×402)

結(jié)論:只有Opera不產(chǎn)生請(qǐng)求。 注意:用visibility: hidden隱藏圖片時(shí),在Opera下也會(huì)產(chǎn)生請(qǐng)求。

2. 重復(fù)圖片

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <img src="haorooms.jpg" />  
  2. <img src="haorooms.jpg" />  

http請(qǐng)求如下:
2016616105640229.jpg (1264×371)

結(jié)論:所有瀏覽器都只產(chǎn)生一次請(qǐng)求 。

3. 重復(fù)背景

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">   
  2.     .test1 { backgroundurl(haorooms.jpg) }   
  3.     .test2 { backgroundurl(haorooms.jpg) }   
  4. </style>   
  5. <div class="test1">test1</div>   
  6. <div class="test2">test2</div>  

http請(qǐng)求如下:
2016616105713640.jpg (1049×382)

結(jié)論:所有瀏覽器都只產(chǎn)生一次請(qǐng)求。

4. 不存在的元素的背景

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">   
  2.     .test1 { backgroundurl(haorooms.jpg) }   
  3.     .test2 { backgroundurl(http2.jpg) } /* 頁(yè)面中沒(méi)有class為test2的元素 */  
  4. </style>   
  5. <div class="test1">test1</div>  

http請(qǐng)求如下:
2016616105755887.jpg (1125×326)

結(jié)論:背景僅在應(yīng)用的元素在頁(yè)面中存在時(shí),才會(huì)產(chǎn)生請(qǐng)求。這對(duì)CSS框架來(lái)說(shuō),很有意義。

5. 隱藏元素的背景

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">   
  2.     .test1 { backgroundurl(haorooms.jpg); displaynone; }   
  3.     .test2 { backgroundurl(http2.jpg); visibilityhidden; }   
  4. </style>   
  5.   
  6. <div class="test1">test1</div>  

http請(qǐng)求如下:
2016616105836960.jpg (1228×324)

結(jié)論:Opera和Firefox對(duì)于用display: none隱藏的元素背景,不會(huì)產(chǎn)生HTTP請(qǐng)求。僅當(dāng)這些元素非display: none時(shí),才會(huì)請(qǐng)求背景圖片。

6. 多重背景

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">   
  2.     .test1 { backgroundurl(haorooms.jpg); }   
  3.     .test1 { backgroundurl(http2.jpg); }   
  4. </style>   
  5. <div class="test1">test1</div>  

上面這段代碼的http請(qǐng)求,只會(huì)請(qǐng)求http2.jpg這一張圖片,原因是test1的class把上面的給覆蓋掉了,所有只請(qǐng)求后面的一張圖片!
假如用css3多張背景圖片的寫法:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">   
  2.     .test1 { background-image:url("haorooms.jpg"),url("http2.jpg"); }   
  3. </style>   
  4. <div class="test1">test1</div>  

那么http請(qǐng)求如下:
2016616105913578.jpg (1370×346)

webkit引擎瀏覽器對(duì)背景圖都請(qǐng)求,是因?yàn)橹С諧SS3中的多背景圖。

7. hover的背景加載

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <style type="text/css">   
  2.     a.test1 { backgroundurl(haorooms.jpg); }   
  3.     a.test1:hover { backgroundurl(http2.jpg); }   
  4. </style>   
  5. <a href="#" class="test1">test1</a>  

http請(qǐng)求如下:
2016616105947450.jpg (1203×343)

結(jié)論:觸發(fā)hover時(shí),才會(huì)請(qǐng)求hover狀態(tài)下的背景。不觸發(fā)的話,只請(qǐng)求默認(rèn)的背景圖片。

8. JS里innerHTML中的圖片

JavaScript Code復(fù)制內(nèi)容到剪貼板
  1. <script type="text/javascript">   
  2.     var el = document.createElement('div');   
  3.     el.innerHTML = '<img src="haorooms.jpg" />';   
  4.     //document.body.appendChild(el);   
  5. </script>  

http請(qǐng)求如下:
2016616110110394.jpg (1257×329)

結(jié)論:只有Opera不會(huì)馬上請(qǐng)求圖片。

注意:當(dāng)添加到DOM樹上時(shí),Opera才會(huì)發(fā)送請(qǐng)求。

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

JavaScript Code復(fù)制內(nèi)容到剪貼板
  1. <script type="text/javascript">   
  2.     new Image().src = 'haorooms.jpg';   
  3.     new Image().src = 'http2.jpg';   
  4. </script>  

在無(wú)JS支持的環(huán)境下,可以采用隱藏元素來(lái)預(yù)加載:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. <img src="haoroomscom.jpg" style="visibility: hidden; height: 0; width: 0" />  

總結(jié)
1、對(duì)于隱藏圖片和隱藏元素的背景,Opera不會(huì)產(chǎn)生請(qǐng)求。
2、對(duì)于隱藏元素的背景,F(xiàn)irefox也不會(huì)產(chǎn)生請(qǐng)求。
3、對(duì)于尚未插入DOM樹的img元素,Opera不會(huì)產(chǎn)生請(qǐng)求。
4、基于webkit引擎的Safari和Chrome,支持多背景圖。
5、其它情景,所有主流瀏覽器保持一致。
希望上面的圖片http請(qǐng)求對(duì)您有所幫助,大家可以相互留言交流!

 

相關(guān)文章

最新評(píng)論