国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

瀏覽器的緩存(2)

impig33 / 1363人閱讀

摘要:的兼容性由于是現代的技術,以下的古老瀏覽器是不支持的。當然也可以手動指定文件這些瀏覽器都不能直接使用緩存,即可能會要求你重新驗證,或者直接使用服務器文件。

親,如果你還在為你沒網打開不網頁而煩惱嗎?
親,你還在為你web服務器復雜的配置項而蛋疼嗎?
不要998,manifest抱回家~
manifest自H5橫空出世以來給前端網頁的瀏覽帶來了翻天覆地的變化,以前我們的網頁必須在有網的前提下打開(主要還是打開HTML), 但是現在,我們可以offline 瀏覽。 可以算是實現web app的一個特技。
manifest的兼容性 IE9+. 由于是現代的技術,IE9以下的古老瀏覽器是不支持的。所以,manifest主要應用是針對現代瀏覽器或者手機端更多一些。

入門manifest

瀏覽器檢測你是否使用manifest特技時,是檢測html標簽.


當解析你的HTML時,發現存在manifest文件時,則會進行如下的操作:

(from alloy team)
manifest文件可以是任意后綴比如. usable.manifest||usable.mf等,但是他的MIMEtype必須設置正確.
記住,這個時候manifest會將HTML文件也一并保存,這需要注意。

書寫manifest文件

一個簡單的demo:

CACHE MANIFEST
#version 1.3
/public/static/index.css
/public/static/header.css
NETWORK:
*
FALLBACK:
/userInfo/ /404.html
#額外需要添加的緩存文件
CACHE:
images/logo1.png
images/logo2.png

基本樣式就是上述

CACHE MANIFEST/CACHE

第一行必須是指定頭即, "CACHE MANIFEST"(不能有其他的). 表示哪些文件需要緩存。如果是相對路徑則是,在manifest文件所在的目錄下。而且,不能使通配符!!!(tm 你是還不是傻). 所以一般而言只能一個一個配置.

CACHE MANIFEST
#相對于manifest文件所在的目錄
    ./index.css 

注釋: 注釋使用#+"info"
可以對緩存文件性質進行適當的說明。緩存后的文件,就會被帶上Expires的頭,表示可以不經過服務器驗證直接使用本地文件。所以,返回status Code 為 200.
另外,CACHE 定義的文件內容,和CACHE MANIFEST 是一個效果,只是跟在CACHE MANIFEST之后,就可以省略書寫CACHE,你添加上也可以。

CACHE MANIFEST
#version 1.3
CACHE:
/favicon.ico

而且CACHE可以放在文中的任意位置,不過一般都是放開頭,或者省略.

CACHE MANIFEST

# 緩存文件
index.html
css/style.css

NETWORK:
*

# 額外的需要緩存的文件
CACHE:
images/logo1.png
images/logo2.png
images/logo3.png
NETWORK

這里設置不使用緩存的文件,可以使用通配符"*"等。
* 表示,除了CACHE MANIFEST定義的文件之外的文件都不能被緩存。
當然也可以手動指定文件:

NETWORK
*
http://www.example.com/index.html
http://www.example.com/header.png
http://www.example.com/blah/blah

這些瀏覽器都不能直接使用緩存,即,可能會要求你重新驗證,或者直接使用服務器文件。

FALLBACK

這個tag,可用可不用。 用來表示,指定文件無法加載時,使用另外的文件代替。參數有兩部分構成,第一部分是指定資源(可能存在文件未加載),第二部分是替代資源

FALLBACK:
/index.html /404.html
/static/* /404.html
/images/* /NotFound.jpg

當index.html無法加載時,使用404.html代替. 這里有個要求,兩個路徑必須使用相對路徑并且與清單文件同源。

SETTINGS

這算是一個附加屬性吧。通常設置內容就只有:

SETTINGS:
prefer-online

表示,在有網的情況下,會先訪問服務器的文件,看有沒有更新,相當于設置了Cache-Control:max-age=0,must-revalidate; + ETag||Last-modified. 不過,比較stupid的是,只有FF(Opera 12)支持.

服務器設置manifest

而在服務器端,需要對manifest文件的MIME設置正確。這里以nginx為例, 具體設置一下MIME type

type{
  image/gif                             gif;  
  image/jpeg                            jpeg jpg;  
  application/x-javascript              js;  
  }

詳情可以參考: manifest文件配置

自動生成manifest文件配置

這里以gulp為例。 可以在npm里面很容易找到gulp-manifest這個生成插件.
直接下載:

npm install gulp-manifest --save-dev

然后在gulpfile里面配置:

gulp.task("manifest", function(){
  gulp.src(["build/**"], { base: "./" })
    .pipe(manifest({
      hash: true,
      preferOnline: true,
      network: ["*"],
      fallback:["/images/* /404.html"]
      filename: "app.manifest",
      exclude: "app.manifest"  //不保存manifest,不過有沒有效果一樣
     }))
    .pipe(gulp.dest("./"));
});

接著就會在目錄下生成app.manifest文件,里面就是一些基本的文件格式了。另外如果你想查看你電腦有多少網頁是manifest,可以直接訪問 chrome://appcache-internals/.

manifest的坑點

manifest對于單頁應用可謂是如魚得水,但是,到了多頁應用的層面,他的bug真的是暴露無遺。

1.頁面保存的復雜度,
2.文件的及時更新,
3.緩存文件的設置, 
4.死都會保存HTML,
5.文件下載出錯,則這次更新緩存失敗,
6.覆蓋所有緩存頭,除了Cache-Control:no-store
7.在Android 4.4的webview里,關閉之后會丟失cache
8.IE10不能很好的支持FALLBACK部分.

所以,appCache的bug也是非常多的。
例如,長尾更新問題,當你的頁面保持在線的時候,是無法檢測文件已經更新,除非你reload頁面,但是用戶并不知道你已經更新,所以這里我們需要引進js的提供的緩存檢測API.

window.applicationCache

這是前端能夠摸到緩存最真實的API。我們可以通過這個API接口獲取到我們很多想要的東西:

var appcache = window.applicationCache;
console.log(appcache.status); //檢查當前緩存狀態
console.log(appcache.IDLE); //緩存狀態常量,下面解釋
常用的屬性有:
屬性名 explanation
status 當前緩存狀態,為Number類型. 為0~5
UNCACHED(0) 瀏覽器未緩存文件
IDLE(1) 空閑狀態,瀏覽器已經全部緩存
CHECKING(2) 頁面正在檢查當前離線緩存是否需要更新
DOWNLOADING(3) 頁面正在下載需要更新的緩存文件
UPDATEREADY(4) 頁面緩存更新完畢
OBSOLETE(5) 緩存已經過期
常用的方法:
window.applicationCache.update()  
//update方法調用時,頁面會主動與服務器通信,檢查頁面當前的緩存是否為最新的,如不是,則下載更新后的資源

window.applicationCache.swapCache()  //updateready后,更新到最新的應用緩存

通常結合上述兩個方法和相應的屬性我們可以手動觸發文件的更新(前提是 manifest文件改動).

var appCache = window.applicationCache;

appCache.update(); 
//檢查更新

if (appCache.status == window.applicationCache.UPDATEREADY) { 
//如果存在更新,并且已經下載ok,則替換瀏覽器緩存
  appCache.swapCache();  
}

但是,此時頁面并不能用上最新的文件,只是瀏覽器的緩存已經改變,網頁實際內容還是原來的內容,還需要手動進行reload,才能進行更新文件

window.addEventListener("load", function(e) {

  window.applicationCache.addEventListener("updateready", function(e) {
    if (window.applicationCache.status == window.applicationCache.UPDATEREADY) {
      if (confirm("文件有更新,手否重新加載文件")) {
        window.location.reload();
      }
    } else {
      //如果,拒絕則不刷新網頁
    }
  }, false);

}, false);
cache相關事件

相關事件有: checking,downloading,updateready,obsolete,cached,error,noupdate,progress.
對照上述的status就可以很容易知道每個事件對應的效果是神馬。 需要說的就是:

progress: 當瀏覽器在下載資源時,每下載成功一次,就會觸發一次
noupdate:當瀏覽器檢查更新之后發現沒有資源更新的時候觸發這個事件
error: 更新出錯時會觸發,比如文件無法正常下載,manifest文件被刪除.

其實,使用manifest的時候,無外乎就是3種常用狀態

第一次訪問頁面時

再次訪問頁面時,沒有更新

再次訪問頁面時,有更新

每次,觸發的事件順序為:

行為 事件順序
第一次訪問頁面 checking->downloading->progress(多次)->cached
再次訪問時,沒有更新 checking->noupdate
再次訪問時,有更新 checking->downloading->progress(多次)->updateready

上面看不懂沒關系,我們可以看看更直觀的Console的內容。

第一次訪問頁面時

checking->downloading->progress(多次)->cache

2. 再次訪問頁面時,沒有更新

checking->noupdate

3. 再次訪問頁面時,有更新

checking->downloading->progress(多次)->updateready

淺談manifest

其實,manifest就是為了離線應用而生的,但是由于設計之初,沒有很好的規范,導致現在manifest的bug,真的超級多。
看到whatwg上面說的一句話,真的更加蛋疼.

This feature is in the process of being removed from the Web platform. (This is a long process that takes many years.) Using any of the offline Web application features at this time is highly discouraged. Use service workers instead.

意思就是讓你不要用manifest,應該他遲早要被fire的,但是,這一天還有很多年,很多年。 另外一個替代方案就是使用SS,但是兼容性,真的極其差。幾乎現在的瀏覽器都沒有實現(除了布道師FF實現了部分). 現在我們真的很尷尬,不過,目前的情況而言,in my opinion, 是十分推薦使用的(也沒有其他的辦法了). 那該怎么做,才能將manifest的Bug減到最低呢?
推薦的做法是將邏輯頁面和用戶數據給分離開。 邏輯頁面使用app cache,而用戶數據可以保存在web Storage || indexDB 等瀏覽器數據庫里,動態更新data時,使用web Socket,ajax,SSE等技術.

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/61784.html

相關文章

  • 一篇文章理解Web緩存

    摘要:的數據將一直保存在瀏覽器內,直到用戶清除瀏覽器緩存數據為止。它也是一個被標準廢棄的功能,主要是通過文件來標注要被緩存的靜態文件清單。盡管也有文件,但是與應用緩存卻完全不同。另外,用來控制緩存的使用。 最近把前端緩存重新整理了一下,從整體的層面上把前端所有能用的緩存方案梳理了一遍。同時,對于http緩存,使用了表格的方案,使得原先晦澀難記的特性變得清晰明了。特記錄于此,若有什么欠缺,也望...

    tangr206 評論0 收藏0
  • 一篇文章理解Web緩存

    摘要:的數據將一直保存在瀏覽器內,直到用戶清除瀏覽器緩存數據為止。它也是一個被標準廢棄的功能,主要是通過文件來標注要被緩存的靜態文件清單。盡管也有文件,但是與應用緩存卻完全不同。另外,用來控制緩存的使用。 最近把前端緩存重新整理了一下,從整體的層面上把前端所有能用的緩存方案梳理了一遍。同時,對于http緩存,使用了表格的方案,使得原先晦澀難記的特性變得清晰明了。特記錄于此,若有什么欠缺,也望...

    zlyBear 評論0 收藏0
  • 淺談覽器緩存

    摘要:最近在項目中遇到了瀏覽器因緩存問題未能成功向后端發送類型請求的,然后順藤摸瓜順便看了看緩存的知識,覺得有必要總結一下。是服務器響應消息頭字段,在響應請求時告訴瀏覽器在過期時間前瀏覽器可以直接從瀏覽器緩存取數據,而無需再次請求。 最近在項目中遇到了IE瀏覽器因緩存問題未能成功向后端發送GET類型請求的bug,然后順藤摸瓜順便看了看緩存的知識,覺得有必要總結一下。 在前端開發中,性能一直都...

    godruoyi 評論0 收藏0
  • 淺談覽器緩存

    摘要:最近在項目中遇到了瀏覽器因緩存問題未能成功向后端發送類型請求的,然后順藤摸瓜順便看了看緩存的知識,覺得有必要總結一下。是服務器響應消息頭字段,在響應請求時告訴瀏覽器在過期時間前瀏覽器可以直接從瀏覽器緩存取數據,而無需再次請求。 最近在項目中遇到了IE瀏覽器因緩存問題未能成功向后端發送GET類型請求的bug,然后順藤摸瓜順便看了看緩存的知識,覺得有必要總結一下。 在前端開發中,性能一直都...

    shiina 評論0 收藏0
  • 覽器緩存看這一篇就夠了

    摘要:瀏覽器緩存作為性能優化的重要一環,對于前端而言,重要性不言而喻。根據瀏覽器發送的修改時間和服務端的修改時間進行比對,一致的話代表資源沒有改變,服務端返回正文為空的響應,讓瀏覽器中緩存中讀取資源,這就大大減小了請求的消耗。 瀏覽器緩存作為性能優化的重要一環,對于前端而言,重要性不言而喻。以前總是一知半解的,所以這次好好整理總結了一下。 1、緩存機制 首先我們來總體感知一下它的匹配流程,如...

    tinysun1234 評論0 收藏0
  • 掌握緩存,不再讓你藍瘦香菇

    摘要:數據庫緩存當應用邏輯較為復雜,頻繁進行數據庫查詢,很容易導致數據庫不堪重荷。單位為指定設置緩存最大的有效時間,定義的是時間長短。 本文內容概要: 1 Web緩存是什么?為什么要使用它?2 Web緩存的類型3 瀏覽器緩存的基本知識3.1 Expires3.2 Last-modified3.3 Cache-Control3.4 ETag4 瀏覽器緩存機制4.1 強緩存應用4.2 協商緩存應...

    Cristic 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<