HTML5 應用程式快取
什麼是應用程式快取Application Cache
HTML5引入了應用程式快取技術,意味著web應用可進行緩存,並在沒有網路的情況下使用,透過建立cache manifest文件,可以輕鬆的建立離線應用程式。
Application Cache帶來的三個優點是:
① 離線瀏覽
② 提升頁面載入速度
③ 降低伺服器壓力
而且主要瀏覽器皆以支援Application Cache,就算不支援也不會對程式造成什麼影響
離線儲存技術
HTML5提出了兩大離線儲存技術:localstorage與Application Cache,兩者各有應用場景;傳統還有離線儲存技術為Cookie。
經過實踐我們認為localstorage應該存儲一些非關鍵性ajax數據,做錦上添花的事情;
Application Cache用於存儲靜態資源,仍然是乾錦上添花的事情;
而cookie只能保存一小段文字(4096位元組);所以不能儲存大數據,這是cookie與上述快取技術的差異之一,而因為HTTP是無狀態的,伺服器為了區分請求是否來自同一個伺服器,需要一個識別字串,而這個任務就是cookie完成的,這一段文字每次都會在伺服器與瀏覽器之間傳遞,以驗證使用者的權限。
所以Application Cache的應用程式場景不一樣,所以使用也不一致。
Application Cache簡介
Application Cache的使用要做兩方面的工作:
① 伺服器端需要維護一個manifest清單
② 瀏覽器上只需要一個簡單的設定即可
<html manifest="demo.appcache">
以範例做說明:
CACHE MANIFEST CACHE: # 需要缓存的列表 style1.css 1.jpg 01.js http://localhost/applicationcache/02.js http://localhost/applicationcache/zepto.js NETWORK: # 不需要缓存的 4.jpg FALLBACK: # 访问缓存失败后,备用访问的资源,第一个是访问源,第二个是替换文件*.html /offline.html 2.jpg/3.jpg
首先我這裡報了一個錯誤:
Application Cache Error event: Manifest fetch failed (404)
這個錯誤的原因是:manifest 檔案需要設定正確的MIME-type,也就是"text /cache-manifest"。必須在web 伺服器上進行配置,不同的伺服器不一樣
\APPLICATIONCACHE 01.js 02.js 1.jpg 2.jpg 3.jpg 4.jpg demo.appcache index.html style1.css style2.css web.config zepto.js
這樣一來便可以離線應用了,這個時候就算斷網了,那些文件依舊能訪問
這裡有一點值得注意,例如這裡不帶/index.html他會將「applicationcache/」緩存,其實這個就是index.html
manifest 檔案可分為三個部分:
CACHE MANIFEST - 在此標題下列出的檔案將在首次下載後進行快取
NETWORK - 在此標題下列出的檔案需要與伺服器的連接,且不會被快取
FALLBACK - 在此標題下列出的檔案規定當頁面無法存取時的回退頁面(例如404 頁面)
Cache Manifest 基礎
如需啟用應用程式緩存,請在文件的<html> 標籤中包含manifest 屬性:
<!DOCTYPE HTML> <html manifest="demo.appcache"> ... </html>
每個指定了manifest 的頁面在使用者對其存取時都會被快取。如果未指定 manifest 屬性,則頁面不會被快取(除非在 manifest 檔案中直接指定了該頁面)。
manifest 檔案的建議的檔案副檔名是:".appcache"。
請注意,manifest 檔案需要設定正確的 MIME-type,即 "text/cache-manifest"。必須在 web 伺服器上進行設定。
Manifest 文件
manifest 文件是簡單的文字文件,它告知瀏覽器被快取的內容(以及不快取的內容)。
manifest 檔案可分為三個部分:
CACHE MANIFEST - 在此標題下列出的檔案將在首次下載後進行快取
NETWORK - 在此標題下列出的檔案需要與伺服器的連接,且不會被快取
FALLBACK - 在此標題下列出的檔案規定當頁面無法存取時的回退頁面(例如404 頁面)
# CACHE MANIFEST
第一行,CACHE MANIFEST,是必要的:
CACHE MANIFEST
/theme.css
/logo.gif
#/main.js
上面的manifest 檔案列出了三個資源:一個CSS 文件,一個GIF 映像,以及一個JavaScript 檔案。當 manifest 檔案載入後,瀏覽器會從網站的根目錄下載這三個檔案。然後,無論用戶何時與網際網路斷開連接,這些資源仍然是可用的。
NETWORK
下面的NETWORK 小節規定檔案"login.php" 永遠不會被緩存,離線時是不可用的:
NETWORK:
login .php
可以使用星號來指示所有其他其他資源/檔案都需要因特網連線:
NETWORK:
*
FALLBACK
實例- 完整的Manifest 檔案
CACHE MANIFEST
# 2012-02-21 v1.0.0
/theme.css
/logo.gif
/main.js
NETWORK:
login.php
FALLBACK:
/html/ /offline.html
提示:以"#" 開頭的是註解行,但也可滿足其他用途。應用程式的快取會在其 manifest 檔案更改時被更新。如果您編輯了一幅圖片,或修改了一個 JavaScript 函數,這些變更都不會重新快取。更新註解行中的日期和版本號碼是一種使瀏覽器重新快取檔案的方法。
關於應用程式快取的說明
請留心快取的內容。
一旦檔案被緩存,瀏覽器會繼續展示已快取的版本,即使您修改了伺服器上的檔案。為了確保瀏覽器更新緩存,您需要更新 manifest 檔案。
注意: 瀏覽器對快取資料的容量限制可能不太一樣(某些瀏覽器設定的限制是每個網站 5MB)。