DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> HTML基礎知識 >> HTML5詳解 >> HTML5 離線應用之打造零請求、無流量網站的解決方法
HTML5 離線應用之打造零請求、無流量網站的解決方法
編輯:HTML5詳解     

前言

今天Web應用程序已經很復雜了,以現在的發展,會將越來越復雜,但他有一個致命缺點,不能脫離internet鏈接,因此在Html中新增了一API,

它使用一個本地存儲機制很好地解決了這個問題,為離線web應用鋪平了道路。
本地緩存於浏覽器緩存

復制代碼代碼如下:
本地緩存是為整個web應用程序服務
浏覽器緩存只對單個網頁服務</p><p>任何網頁都具有網頁緩存
本地緩存只緩存那些你指定緩存的頁面</p><p>網頁緩存不可靠、不安全,因為我們不知道網站中到底緩存了哪些頁面、哪些資源
本地緩存可以控制對哪些內容進行緩存

manifest文件

web應用程序本地緩存是通過每個頁面的manifest文件來管理的,manifest是一簡單文本,在該文件中以清單的形式列舉了需要被緩存的不需要被緩存的文件的名字、路徑。

可以為每個頁面單獨指定manifest也可以為整個應用程序指定,例我們為hello.htm的設置:

復制代碼代碼如下:
CACHE MANIFEST
CACHE:
other.Html
hellow.JS
images/myphoto.jpg
NETWORK:
http://LuLinniu/NotOffline
NotOffline.ASP
*
FALLBACK:
online.js locale.JS
CACHE:
newhellow.Html
newhellow.JS

在manifest文件中,第一行必須是CACHE MANIFEST,以把文本的作用告訴浏覽器,即對本地緩存中的資源文件進行具體設置。
同時真正運行離線web應用程序時,需要對服務器進行配置,讓服務器支持text/cache-manifest這個mime類型。

在指定文件源文件時可以把資源文件分為三類,CACHE、NETWORK、FALLBACK

復制代碼代碼如下: </p><p>在CACHE類別中指定需要被緩存在本地的資源文件,為某個頁面指定需要本地緩存的資源文件時,不需要把這個頁面本身指定在CACHE類別中,
因為如果一個頁面具有manifest文件,浏覽器會自動對該頁面進行本地緩存</p><p>NETWORK類別為顯式指定不進行緩存的資源文件,這些文件只有建立服務器端鏈接才能訪問,本例使用通配符*表示沒有進行記錄的都不緩存</p><p>FALLBACK類別中的每行中指定兩個資源文件,第一個資源文件為能夠在線訪問時使用的資源文件,第二個為不能在線訪問時使用的本地緩存文件

浏覽器與服務器交互過程

當使用離線web應用程序進行工作時,有必要了解浏覽器與服務器之間的交互過程:

復制代碼代碼如下:
比如一個http://LuLingniu,以index.htm為主頁,該主頁使用index.manifest,
在文件中緩存index.htm,hello.JS,hello.jpg,首次訪問時流程如下:
浏覽器請求url
服務器返回index.htm首頁
浏覽器解析index.htm網頁,請求頁面上所有資源文件
服務器返回資源文件
浏覽器處理manifest文件,請求manifest中需要緩存的文件,即使請求過亦會再請求
服務器返回需要緩存的文件
浏覽器對本地緩存進行更新,存入資源文件,並觸發一個事件通知本地緩存更新</p><p>再次打開該URL
請求url 
浏覽器發現頁面被緩存,於是使用本地緩存文件
解析文件
浏覽器像服務器請求manifest文件
服務器返回304,通知manifest文件沒有變化(若是改變將會有所不同)

applicationCache對象

該對象代表了本地緩存,可以用它來通知用戶本地緩存已經被更新,也允許手動更新本地緩存。

前面當浏覽器對本地緩存做了更新裝入新資源文件時,會觸發applicationCache對象的updateready事件,通知本地緩存已被修改,然後提示用戶手動刷新頁面。
swapCache

swapCache方法用來手動執行本地緩存的更新,它只能在applicationCache對象的updateReady事件觸發時調用,

即當資源文件發生改變時,可使用此方法手工緩存更新。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved