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

資訊專欄INFORMATION COLUMN

構(gòu)建離線WEB應用

lk20150415 / 2672人閱讀

摘要:使用離線應用構(gòu)建應用服務端服務器配置創(chuàng)建文件客戶端構(gòu)建,并在標簽上添加屬性,屬性值是服務器上配置的緩存資源列表的文件名配置相關(guān)事件,創(chuàng)建離線文件內(nèi)容將狀態(tài)代碼轉(zhuǎn)化成狀態(tài)離線應用創(chuàng)建即使沒有互聯(lián)網(wǎng)連接也可以使用的應用程序。

HTML5新增了localstroage和application cache做離線緩存,兩種緩存各有應用的場景,今天我們說說application cache這種方案。

web當中使用緩存的原因之一是為了支持離線應用,其它優(yōu)點:

減少網(wǎng)絡資源的請求(減少服務器壓力)

相比網(wǎng)絡加載資源,加載本地資源速度更快,體驗更好

在斷網(wǎng)的情況下,能提供良好的用戶體驗(斷網(wǎng)加載)

通常緩存的資源包括:HTML文檔,JS文件,CSS文件,圖片,多媒體
application cache 緩存的資源文件,通常保存在瀏覽器持久性存儲資源的地方,也就是在本地硬盤上面

使用HTML5離線WEB應用API:

1、檢查瀏覽器是否支持

    if(window.applicationCache){
        // 則支持離線緩存
    }

2、在html文檔的HTML元素上添加manifest特性,如下:

    
        
        
    

3、在application.appcache文件中,定義緩存文件清單,比如:

    CACHE MANIFEST

4、支持離線行為
HTML5引入了一些新的事件,可以讓應用程序檢測網(wǎng)絡是否正常連接。這樣就可以控制應用程序在離線和在線的時候有不同的行為,HTML5當中可以通過檢測window.navigator對象來做判斷,navigator.onLine是一個標明瀏覽器是否在線的布爾屬性,我們可以通過以下代碼作相應的判斷:

    function loadDemo(){
        if(navigator.onLine){
            log("online")
        }else{
            log("offline")
        }
    }
    
    // 添加事件
    window.addEventListener("online",function(e){
        log("online")
    });

5、manifest文件
離線應用當中包含一個manifest的文件,文件當中列出了瀏覽器為離線應用緩存的所有資源列表。manifest的文件MIME類型是text/cache-manifest
文件示例:

CACHE MANIFEST
# 要換成的文件
about.html
html5.css
index.html
a.gif
b.jpg

#不緩存的文件  # 每次都會從服務器拉去新的文件,因為瀏覽器會緩存,為了保證每次的內(nèi)容都是服務器上最新的,應當在這里
NETWORK
signup.html


#獲取不到資源文件時候的備選資源路徑,一般出現(xiàn)404的時候會使用
FALLBACK
signup.html     offline.html  #當訪問signup.html出現(xiàn)404的時候,會轉(zhuǎn)到offline.html
/app/ajax       offline.html  #當訪問/app/ajax路徑下的內(nèi)容出現(xiàn)404的時候,會轉(zhuǎn)到offline.html

6、applicationCache API
applicationCache API是一個操作應用緩存的接口。

window.applicationCache.status,代表了緩存的狀態(tài),一共有6種,如下表:

數(shù)值型屬性 緩存狀態(tài) 說明
0 UNCACHED(未緩存) 沒有指定緩存清單
1 IDLE(空閑) 帶有緩存清單應用的狀態(tài),表示所有文件都已被緩存
2 CHECKING(檢查中)
3 DOWNLOADING(下載中) 1
4 UPDATEREADY(更新就緒) 1
5 OBSOLETE(過期) 1

相關(guān)事件

事件 關(guān)聯(lián)的緩存狀態(tài)
Onchecking CHECKING
Ondownloading DOWNLOADING
Onupdateready UPDATEREADY
Onobsolete OBSOLETE
Oncached IDLE

沒有更新或者更新發(fā)生錯誤,
onerror
onnoupdate
onprogress

window.applicationCache.update——會請求瀏覽器更新緩存,包括檢查新版本的manifest文件,并下載必要的新資源,如果沒有緩存,或者緩存已過期,則會拋出錯誤。

7、運行中的應用緩存
如果應用使用了離線緩存,瀏覽器在應用緩存中已經(jīng)成功緩存了manifest列表當中的內(nèi)容之后,它會優(yōu)先的從緩存當中獲取資源,之后,瀏覽器只干一件事,就是檢查manifest文件是否已經(jīng)被改變過,流程如下:

首次訪問,瀏覽器加載頁面及其資源

解析頁面的時候,瀏覽器會解讀HTML元素的manifest屬性,然后加載CACHE 和FALLBACK部分列出的文件,到xxx.com應用的緩存,瀏覽器大于5M的存儲空間

再次訪問應用網(wǎng)站的時候,瀏覽器會從緩存當中加載資源文件,同時,如果應用在線,則會檢查manifest文件是否更新過

離線狀態(tài),瀏覽器會從資源緩存中加載,而訪問NETWORK資源時,會加載FALLBACK的內(nèi)容。

當應用處于在線狀態(tài),修改了緩存文件列表當中的某一個文件,但是,沒有更新manifest(沒發(fā)生變化),那么瀏覽器依然會從瀏覽器緩存當中加載這個文件。這時候,需要稍微再manifest文件當中修改字符(一般是版本號),瀏覽器才會加載最新的manifest文件

當修改了緩存的文件,也修改了manifest文件,但刷新瀏覽器的時候,依然看到的是原來緩存的內(nèi)容,因為頁面從應用緩存中加載資源時發(fā)生在服務器執(zhí)行服務器檢查之前,瀏覽器是不會自動更新加載頁面的。可以把瀏覽器關(guān)掉,再次打開,也可以通過updateready事件綁定監(jiān)聽,提示用戶進行刷新。

使用HTML5離線應用(applicationCache )構(gòu)建應用
    服務端:
    1、服務器配置
    2、創(chuàng)建manifest文件
    
    客戶端:
    3、構(gòu)建HTML,并在HTML標簽上添加manifest屬性,屬性值是服務器上配置的緩存資源列表的文件名
    4、配置相關(guān)事件,創(chuàng)建離線Javascript

Js文件內(nèi)容:

    window.applicationCache.onchecking = function(e){
        log("")
    }
    
    window.applicationCache.onnoupdate = function(e){};
    window.applicationCache.onupdateready = function(e){};
    window.applicationCache.onobsolete = function(e){};
    window.applicationCache.ondownloading = function(e){};
    window.applicationCache.oncached = function(e){};
    window.applicationCache.onerror = function(e){}
    
    window.addEventListener("online",function(e){
        
    });
    
    window.addEventListener("offline",function(e){
        
    });
    
    /*
        將applicationCache狀態(tài)代碼轉(zhuǎn)化成狀態(tài)
    */
    showCacheStatus = function(n){
        statusMessages =  ["Uncached","Idle","Checking","Donwloading","Update Ready","Obsolete"];
    
        return statusMessages[n];
    }
    
    let install = function(){
        log("checking for updates");
        try{
            window.applicationCache.update();
        }cache(e){
            applicationCache.onerror();
        }
        
    }
    ...

HTML5離線WEB應用創(chuàng)建即使沒有互聯(lián)網(wǎng)連接也可以使用的應用程序。為確保應用中所需文件能夠成功緩存,需要將這些文件指定在manifest文件中,隨后在應用程序的主頁面中進行引用。然后,添加監(jiān)聽器監(jiān)聽在線和離線狀態(tài)的變化,進而基于因特網(wǎng)連接是否讓網(wǎng)站執(zhí)行不同的操作。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/114656.html

相關(guān)文章

  • 構(gòu)建離線WEB應用

    摘要:使用離線應用構(gòu)建應用服務端服務器配置創(chuàng)建文件客戶端構(gòu)建,并在標簽上添加屬性,屬性值是服務器上配置的緩存資源列表的文件名配置相關(guān)事件,創(chuàng)建離線文件內(nèi)容將狀態(tài)代碼轉(zhuǎn)化成狀態(tài)離線應用創(chuàng)建即使沒有互聯(lián)網(wǎng)連接也可以使用的應用程序。 HTML5新增了localstroage和application cache做離線緩存,兩種緩存各有應用的場景,今天我們說說application cache這種方案...

    shleyZ 評論0 收藏0
  • 構(gòu)建離線web應用(一)

    摘要:我喜歡移動,而且也是那些堅持使用技術(shù)構(gòu)建移動應用程序的人之一。我們準備做這樣的一個漸進式應用是典型的旨在提高用戶離線體驗的應用。當我們開始構(gòu)建應用時,你就能理解上面的場景了。的作用范圍是針對相對路徑的。最佳的做法是在應用的入口。 我喜歡移動app,而且也是那些堅持使用Web技術(shù)構(gòu)建移動應用程序的人之一。 經(jīng)過技術(shù)的不斷迭代(可能還有一些其它的東西),移動體驗設計愈來愈平易近人,給予用戶...

    Sanchi 評論0 收藏0
  • js構(gòu)建離線應用

    摘要:技術(shù)實現(xiàn)離線應用的核心是離線緩存技術(shù),歷史上曾先后出現(xiàn)兩種離線緩存技術(shù)。新的線程取得控制權(quán)后,將會觸發(fā)其事件。接入用構(gòu)建接入的離線應用時,要解決的問題在于如何生成之前提到的文件。 內(nèi)容主要引用自吳浩麟著《webpack深入淺出》 離線應用 離線應用的優(yōu)點: 在沒有網(wǎng)絡的情況下能打開網(wǎng)頁。 由于部分緩存的資源直接從本地加載,所以對用戶來說可以加快網(wǎng)頁的加載速度,減少服務器壓力。 技術(shù)實...

    phoenixsky 評論0 收藏0
  • 創(chuàng)建一個離線優(yōu)先,數(shù)據(jù)驅(qū)動的漸進式 Web 應用程序

    摘要:原文地址譯文出自我的個人博客概述在本文中,您將學習如何使用和創(chuàng)建離線優(yōu)先數(shù)據(jù)驅(qū)動的漸進式應用程序。在離線的情況下也可以使用后臺同步功能將應用程序與服務器同步。保存數(shù)據(jù)到中現(xiàn)在我們保存數(shù)據(jù)到剛創(chuàng)建的數(shù)據(jù)庫中的對象中。 原文地址:Build an offline-first, data-driven PWA譯文出自:我的個人博客 概述 在本文中,您將學習如何使用 Workbox 和 In...

    csRyan 評論0 收藏0

發(fā)表評論

0條評論

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