前端 - 關于瀏覽器緩存html文件
問題描述
最近在學習瀏覽器的緩存機制,看到有一種方案,使用強緩存,資源名用文件名+md5來命名,實現資源的更新,對于這個方案有幾點疑問:
是否每次修改了資源,都要在html中修改link標簽,把url指向最新的資源。這樣不會很麻煩嗎?尤其是同一個資源被無數html引用的時候(所以會有類似的工具/腳本?)
瀏覽器也會緩存這個html文件,那么html文件自身如何更新呢?比如我用node寫個服務器,可能一句app.use(’/’, index);就好了,但是每次瀏覽器也會對html進行緩存,如果用到上述這種方案的話,是否應該在服務器這里做出改動,讓所有返回的html文件,都不使用強緩存,這樣每次就可以加載到最新修改的html了。(我也查看了幾家大網站的F12,有的html就是200,比如百度和網易,新浪這種還是返回的304)
可以講一講詳細的方案嗎。。查看很多資料都是一句“資源名+md5命名,每次加載最新的資源”,初學者在實現上有些看不懂。。。
問題解答
回答1:-> 1, 每次資源更新, HTML 是需要更新的, 這通過代碼來完成, 比如 HTML 頁面是個模板引擎, md5 文件后綴通過 Webpack 生成, 渲染一下就好.
-> 2, 看具體策略吧. 如果是靜態(tài)文件, 一般通過 HTTP 協(xié)議檢查文件的更新時間或者 etag, 不更新返回 304, 更新返回 200. HTML 文件放在服務器, 跟靜態(tài)資源放在 CDN 生成 200(from cache) 區(qū)分開. 如果頁面是需要針對每個請求渲染生成, 那一般就是 200 了.
-> 3, 整個過程麻煩地很, 根據業(yè)務和工具鏈還會有變化, 太復雜, 一般人沒心情講. 推薦去把國外的博客看, 比如 https://medium.com/@okonetchn...
相關文章:
1. macos - 無法source activate python272. 運行python程序時出現“應用程序發(fā)生異常”的內存錯誤?3. css3:flex排版問題4. github - 求助大神啊,win10 git clone error,折騰了幾天都不行,以前原本好好的,突然就這樣了5. android - 如何實現QQ pad 點擊右側輸入框,只頂右側的布局,左側布局不動6. javascript - npm run build后調用api返回index.html7. css - 關于background-position百分比的問題?8. css - hexo+github搭建博客9. css - angular前端如何讓ng-repeat的內容并排一行,跑起來呢?10. 小白學python的問題 關于%d和%s的區(qū)別

網公網安備