溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

CSS中怎么控制前端圖片HTTP請求

發(fā)布時間:2021-07-22 15:35:51 來源:億速云 閱讀:159 作者:Leah 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)CSS中怎么控制前端圖片HTTP請求,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

1. 隱藏圖片

XML/HTML Code復(fù)制內(nèi)容到剪貼板

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

http請求如下:
CSS中怎么控制前端圖片HTTP請求

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

2. 重復(fù)圖片

XML/HTML Code復(fù)制內(nèi)容到剪貼板

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

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

http請求如下:
CSS中怎么控制前端圖片HTTP請求

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

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請求如下:
CSS中怎么控制前端圖片HTTP請求

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

4. 不存在的元素的背景

CSS Code復(fù)制內(nèi)容到剪貼板

  1. <style type="text/css">   

  2.     .test1 { backgroundurl(haorooms.jpg) }   

  3.     .test2 { backgroundurl(http2.jpg) } /* 頁面中沒有class為test2的元素 */  

  4. </style>   

  5. <div class="test1">test1</div>  

http請求如下:
CSS中怎么控制前端圖片HTTP請求

結(jié)論:背景僅在應(yīng)用的元素在頁面中存在時,才會產(chǎn)生請求。這對CSS框架來說,很有意義。

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請求如下:
CSS中怎么控制前端圖片HTTP請求

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

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請求,只會請求http2.jpg這一張圖片,原因是test1的class把上面的給覆蓋掉了,所有只請求后面的一張圖片!
假如用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請求如下:
CSS中怎么控制前端圖片HTTP請求

webkit引擎瀏覽器對背景圖都請求,是因為支持CSS3中的多背景圖。

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請求如下:
CSS中怎么控制前端圖片HTTP請求

結(jié)論:觸發(fā)hover時,才會請求hover狀態(tài)下的背景。不觸發(fā)的話,只請求默認(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請求如下:
CSS中怎么控制前端圖片HTTP請求

結(jié)論:只有Opera不會馬上請求圖片。

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

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>  

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

CSS Code復(fù)制內(nèi)容到剪貼板

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

總結(jié)
1、對于隱藏圖片和隱藏元素的背景,Opera不會產(chǎn)生請求。
2、對于隱藏元素的背景,F(xiàn)irefox也不會產(chǎn)生請求。
3、對于尚未插入DOM樹的img元素,Opera不會產(chǎn)生請求。
4、基于webkit引擎的Safari和Chrome,支持多背景圖。
5、其它情景,所有主流瀏覽器保持一致。

關(guān)于CSS中怎么控制前端圖片HTTP請求就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI