午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

javascript - 請問 chrome 為什么會重復加載圖片資源?

瀏覽:317日期:2023-03-26 18:39:55

問題描述

javascript - 請問 chrome  為什么會重復加載圖片資源?

如圖所示,發現預加載圖片后,重復調用圖片的時候觸發了重復的圖片資源( 確定圖片資源路徑是一致的 )加載。

在手機端沒有發現這樣的情況,但是在 chrome 上很容易出現類似的情況,每次重復加載的圖片資源不相同。

重復請求一兩次后,便不會再重復請求。

請問是什么原因導致了這樣的情況出現?

html 頭部

<meta name='viewport' content='width=device-width, initial-scale=1.0, user-scalable=0, minimum-scale=1.0, maximum-scale=1.0'><meta name='format-detection' content='telephone=no, date=no, address=no, email=no, url=no'><meta http-equiv='Cache-Control' content='no-cache, no-store, must-revalidate'><meta http-equiv='Pragma' content='no-cache'><meta http-equiv='Expires' content='0'>

stackoverflow 上相同問題:https://stackoverflow.com/que...

問題解答

回答1:

http請求是304,實際上這張圖片是從瀏覽器緩存里面加載的

引用: 對 HTTP 304 的理解

最近和同事一起看Web的Cache問題,又進一步理解了 HTTP 中的 304 又有了一些了解。 304 的標準解釋是:Not Modified 客戶端有緩沖的文檔并發出了一個條件性的請求(一般是提供If-Modified-Since頭表示客戶只想比指定日期更新的文檔)。服務器告訴客戶,原來緩沖的文檔還可以繼續使用。 如 果客戶端在請求一個文件的時候,發現自己緩存的文件有 Last Modified ,那么在請求中會包含 If Modified Since ,這個時間就是緩存文件的 Last Modified 。因此,如果請求中包含 If Modified Since,就說明已經有緩存在客戶端。只要判斷這個時間和當前請求的文件的修改時間就可以確定是返回 304 還是 200 。對于靜態文件,例如:CSS、圖片,服務器會自動完成 Last Modified 和 If Modified Since 的比較,完成緩存或者更新。但是對于動態頁面,就是動態產生的頁面,往往沒有包含 Last Modified 信息,這樣瀏覽器、網關等都不會做緩存,也就是在每次請求的時候都完成一個 200 的請求。 因此,對于動態頁面做緩存加速,首先要在 Response 的 HTTP Header 中增加 Last Modified 定義,其次根據 Request 中的 If Modified Since 和被請求內容的更新時間來返回 200 或者 304 。雖然在返回 304 的時候已經做了一次數據庫查詢,但是可以避免接下來更多的數據庫查詢,并且沒有返回頁面內容而只是一個 HTTP Header,從而大大的降低帶寬的消耗,對于用戶的感覺也是提高。 當這些緩存有效的時候,通過 HttpWatch 查看一個請求會得到這樣的結果:

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 毛片毛片毛片毛片毛片毛片毛片毛片 | 欧洲精品一区二区 | 国产精品12区| 欧美色图自拍 | av最新天堂 | 国产又大又黄的视频 | 丁香九月婷婷 | 插的太深了| 亚洲视频重口味 | 全部免费毛片在线播放 | 国产成人精品亚洲男人的天堂 | 国产另类精品 | 9600kf| 99ri在线| 久久久午夜精品 | 久久免费高清 | 视频一区二区三区在线观看 | 日日摸日日 | 色综久久 | 丁香综合五月 | 国产色中色 | 国产一区二区三区久久 | 四虎影院最新网址 | 亚洲欧美一二三区 | 黄片毛片在线观看 | 91麻豆成人精品国产 | 黄色欧美视频 | 天天操天天爱天天干 | 亚洲人成在线观看 | 欧美亚洲国产另类 | 国产高清视频 | 99re视频| 黄色av网页 | 欧美专区一区 | 天堂资源av| 欧美一级爆毛片 | 国产传媒在线看 | 久久不卡视频 | 久久五月婷 | 粉嫩av在线播放 | 毛片网站视频 |