位置:首頁(yè) > 軟件操作教程 > 編程開(kāi)發(fā) > HTML > 問(wèn)題詳情

HTML5 applicationCache 對(duì)象

提問(wèn)人:劉團(tuán)圓發(fā)布時(shí)間:2020-11-17

    applicationCache對(duì)象代表本地緩存,可以用它來(lái)通知用戶本地緩存已經(jīng)被更新,也允許用戶手工更新本地緩存。在瀏覽器與服務(wù)器的交互過(guò)程中,當(dāng)瀏覽器對(duì)本地緩存進(jìn)行更新并加入新的資源文件時(shí),會(huì)觸發(fā)applicationCache對(duì)象的updateready事件,通知本地緩存已經(jīng)被更新。可以利用該事件告訴用戶本地緩存已經(jīng)被更新,用戶需要手工刷新頁(yè)面來(lái)得到最新版本的應(yīng)用程序,代碼如下:

    applicationCache.addEventListener("updateready", function(event) {

    // 本地緩存已鉍寅新,通知用戶。

    alert("本地緩存已被更新,可以刷新頁(yè)面來(lái)得到本程序的最新版本。");

    },false);

    另外,可以通過(guò)applicationCache對(duì)象的swapCache()方法,來(lái)控制如何進(jìn)行本地緩存的更新及更新的時(shí)機(jī),代碼如下:

    swapCache()方法

    該方法用來(lái)手工執(zhí)行本地緩存的更新,它只能在applicationCache對(duì)象的updateReady事件被觸發(fā)時(shí)調(diào)用。updateReady事件只有在服務(wù)器上的manifest文件被更新,并且把manifest文件中所要求的資源文件下載到本地后觸發(fā)。該事件的含義是“本地緩存準(zhǔn)備被更新”。當(dāng)這個(gè)事件被觸發(fā)后,可以用swapCacheO方法來(lái)手工進(jìn)行本地緩存的更新。

    如果本地緩存的容量非常大,本地緩存的更新工作將需要相對(duì)較長(zhǎng)的時(shí)間,而且會(huì)把瀏覽器鎖住。這時(shí)最好有個(gè)提示,告訴用戶正在進(jìn)行本地緩存的更新,代碼如下:

    applicationCache.addEventliistener("updateready", function(event) {

    // 本地緩存已被更新,通知用戶。

    alert("正在更新本地緩存……");

    applicationGaphe.swjap.Giacihe();

    alert("本地緩存更新完畢,可以刷新頁(yè)面使用最新版應(yīng)用程序?!保?

    },false) ;

    在以上代碼中,如果不使用swapCacheO方法,本地緩存一樣會(huì)被更新,但是更新的時(shí)候不一樣。如果不調(diào)用該方法,本地緩存將在下一次打開(kāi)本頁(yè)面時(shí)被更新;如果調(diào)用該方法,則本地緩存將會(huì)被立刻更新。因此,可以使用confirm()方法讓用戶選擇更新時(shí)機(jī),是立刻,還是下次打開(kāi)頁(yè)面時(shí)更 新,特別是當(dāng)用戶可能正在頁(yè)面上執(zhí)行一個(gè)較大操作的時(shí)候。

    另外,盡管使用swapCacheO方法立刻更新了本地緩存,但是并不意味著我們頁(yè)面上的圖像和腳本文件也會(huì)被立刻更新,它們都是在重新打開(kāi)本頁(yè)面時(shí)才會(huì)生效。下面是較完整的示例,HTML代碼如下:

    <!DOCTYPE html>

    <html manifest="swapCache.manifest">

    <head>

    <meta charset="UTF-8"/>

    <title>swapCache()方法示例</title>

    <script type="text/JavaScript" src= "js/script.js"></script>

    </head〉

    <body>

    <p>swapCache()方法不例。</p>

    </body>

    </html>

    JS代碼如下:

    document.addEventListener ("load",function(event) {

    setInterval(function() {

    // 手工檢查是否有更新 

    applicationCache.update();

    }, 5000);

    applicationCache.addEventListener("updateready", function(event) {

    if(confirm("本地緩存已被更新,需要刷新頁(yè)面獲取最新版本嗎?"){

    //手工更新本地緩存

    applicationCache.swapCache();

    //重載頁(yè)面

    location.reload();

    }

    }, false);

    });

    該頁(yè)面使用的manifest文件的內(nèi)容如下:

    Txt代碼

    CACHE MANIFEST 

    #version 1.20 

    CACHE: 

    script.js

繼續(xù)查找其他問(wèn)題的答案?

相關(guān)視頻回答
回復(fù)(0)
返回頂部