用到離線存儲的原因:越來越多的APP使用H5開發(fā),通過瀏覽器進行訪問,瀏覽器訪問就需要互聯(lián)網(wǎng)請求,在手機斷網(wǎng)的情況下,就無法使用APP,而且很多資源是不需要隨時更改的,綜合這些原因,h5提供了一個新特性–離線存儲。 用法:在頁面頭部加入manifest
<!DOCTYPE HTML><html manifest = "cache.manifest">...</html>cache.manifest文件里面寫
CACHE MANIFEST#v0.11//版本號CACHE: //需要離線存儲的資源列表,包含manifest文件的頁面將被自動離線存儲,所以不需要把頁面自身也列出來js/app.jsCSS/style.cssNETWORK: //這下面的資源只有在線情況才能訪問,不會被離線存儲。但是在CACHE和NETWORK都有的資源還是會離線存儲,CACHE優(yōu)先級更高resourse/logo.pngFALLBACK: //如果訪問第一個資源失敗,就用FALLBACK下的資源替換。/ /offline.html //這個文件表示的就是如果訪問根目錄下任何一個資源失敗了,那么就去訪問offline.html。瀏覽器解析manifest :在線情況下,瀏覽器會識別manifest 屬性,會請求manifest文件,如果是第一次訪問,瀏覽器會根據(jù)manifest 文件存儲資源,如果非第一次訪問,瀏覽器會使用離線資源加載頁面,然后對比manifest 文件是否改變,如果改變重新下載文件中資源。離線情況瀏覽器會直接使用離線存儲的資源。 注意:①如果服務(wù)器對離線的資源進行了更新,那么必須更新manifest文件之后這些資源才能被瀏覽器重新下載,如果只是更新了資源而沒有更新manifest文件的話,瀏覽器并不會重新下載資源,也就是說還是使用原來離線存儲的資源。 ②對于manifest文件進行緩存的時候需要十分小心,因為可能出現(xiàn)一種情況就是你對manifest文件進行了更新,但是http的緩存規(guī)則告訴瀏覽器本地緩存的manifest文件還沒過期,這個情況下瀏覽器還是使用原來的manifest文件,所以對于manifest文件最好不要設(shè)置緩存。 ③瀏覽器在下載manifest文件中的資源的時候,它會一次性下載所有資源,如果某個資源由于某種原因下載失敗,那么這次的所有更新就算是失敗的,瀏覽器還是會使用原來的資源。 ④在更新了資源之后,新的資源需要到下次再打開app才會生效,如果需要資源馬上就能生效,那么可以使用window.applicationCache.swapCache()方法來使之生效,出現(xiàn)這種現(xiàn)象的原因是瀏覽器會先使用離線資源加載頁面,然后再去檢查manifest是否有更新,所以需要到下次打開頁面才能生效。
文章參考:https://segmentfault.com/a/1190000000732617
新聞熱點
疑難解答