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

圖片的http請(qǐng)求,有很多種情況,那么究竟什么情況下面不會(huì)發(fā)生請(qǐng)求呢?下面我用案例一一列舉一下,希望對(duì)你深入了解http圖片請(qǐng)求有所幫助。
1. 隱藏圖片
- <img src="haorooms.jpg" style="display: none" />
http請(qǐng)求如下:
結(jié)論:只有Opera不產(chǎn)生請(qǐng)求。 注意:用visibility: hidden隱藏圖片時(shí),在Opera下也會(huì)產(chǎn)生請(qǐng)求。
2. 重復(fù)圖片
- <img src="haorooms.jpg" />
- <img src="haorooms.jpg" />
http請(qǐng)求如下:
結(jié)論:所有瀏覽器都只產(chǎn)生一次請(qǐng)求 。
3. 重復(fù)背景
- <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請(qǐng)求如下:
結(jié)論:所有瀏覽器都只產(chǎn)生一次請(qǐng)求。
4. 不存在的元素的背景
- <style type="text/css">
- .test1 { background: url(haorooms.jpg) }
- .test2 { background: url(http2.jpg) } /* 頁(yè)面中沒(méi)有class為test2的元素 */
- </style>
- <div class="test1">test1</div>
http請(qǐng)求如下:
結(jié)論:背景僅在應(yīng)用的元素在頁(yè)面中存在時(shí),才會(huì)產(chǎn)生請(qǐng)求。這對(duì)CSS框架來(lái)說(shuō),很有意義。
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請(qǐng)求如下:
結(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(haorooms.jpg); }
- .test1 { background: url(http2.jpg); }
- </style>
- <div class="test1">test1</div>
上面這段代碼的http請(qǐng)求,只會(huì)請(qǐng)求http2.jpg這一張圖片,原因是test1的class把上面的給覆蓋掉了,所有只請(qǐng)求后面的一張圖片!
假如用css3多張背景圖片的寫法:
- <style type="text/css">
- .test1 { background-image:url("haorooms.jpg"),url("http2.jpg"); }
- </style>
- <div class="test1">test1</div>
那么http請(qǐng)求如下:
webkit引擎瀏覽器對(duì)背景圖都請(qǐng)求,是因?yàn)橹С諧SS3中的多背景圖。
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請(qǐng)求如下:
結(jié)論:觸發(fā)hover時(shí),才會(huì)請(qǐng)求hover狀態(tài)下的背景。不觸發(fā)的話,只請(qǐng)求默認(rèn)的背景圖片。
8. JS里innerHTML中的圖片
- <script type="text/javascript">
- var el = document.createElement('div');
- el.innerHTML = '<img src="haorooms.jpg" />';
- //document.body.appendChild(el);
- </script>
http請(qǐng)求如下:
結(jié)論:只有Opera不會(huì)馬上請(qǐng)求圖片。
注意:當(dāng)添加到DOM樹上時(shí),Opera才會(huì)發(fā)送請(qǐng)求。
9. 圖片預(yù)加載
最常用的是JS方案:
- <script type="text/javascript">
- new Image().src = 'haorooms.jpg';
- new Image().src = 'http2.jpg';
- </script>
在無(wú)JS支持的環(huán)境下,可以采用隱藏元素來(lái)預(yù)加載:
- <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)文章
30種CSS3炫酷頁(yè)面預(yù)加載loading動(dòng)畫特效源碼
本代碼是一組效果非常炫酷的CSS3頁(yè)面預(yù)加載loading動(dòng)畫特效源碼,當(dāng)點(diǎn)擊頁(yè)面的任何一個(gè)地方時(shí),loading動(dòng)畫就會(huì)被隱藏2017-05-24- 這是一組使用純CSS3制作的預(yù)加載動(dòng)畫特效代碼。共有3種動(dòng)畫效果,分別是翻書效果,搖晃動(dòng)畫和旋轉(zhuǎn)動(dòng)畫,需要的可以下載試試2017-03-07
CSS3 預(yù)加載Loading動(dòng)畫特效源碼
CSS3 Loading預(yù)加載動(dòng)畫特效源碼是一款使用before和after偽元素,以及CSS幀動(dòng)畫來(lái)完成各種不同的預(yù)加載指示器動(dòng)畫,感興趣的朋友可以直接下載源碼哦2016-06-30純CSS圖片預(yù)加載實(shí)例 擺脫Javascript預(yù)載的束縛
有很多種方法來(lái)實(shí)現(xiàn)圖片的預(yù)加載,通常大部分使用Javascript讓事情滾動(dòng)。不要再受Javascript預(yù)載的束縛了吧,用CSS你就可以毫不麻煩的預(yù)載你的圖片,需要的朋友可以了解下2012-12-19CSS 實(shí)現(xiàn)網(wǎng)頁(yè)圖片的預(yù)加載
有很多種方法來(lái)實(shí)現(xiàn)圖片的預(yù)加載,通常大部分使用Javascript讓事情滾動(dòng)。不要再受Javascript預(yù)載的束縛了吧,用CSS你就可以毫不麻煩的預(yù)載你的圖片。2009-10-28純CSS實(shí)現(xiàn)預(yù)加載動(dòng)畫效果
本文給大家分享一段簡(jiǎn)單的代碼實(shí)現(xiàn)css預(yù)加載動(dòng)畫效果,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下吧2017-09-06