1

開発中の Web アプリからすべての js、img、swf、および css をキャッシュする managedStore を作成しようとしています。

コードは次のとおりです。

$(document).ready(function() {
    var manifestName = 'cache_manifest.json';
    var storeName = 'cache';
    var localServer;
    var localStore;
    if (window.google && google.gears) {
        localRequest = google.gears.factory.create('beta.httprequest');
        localServer = google.gears.factory.create('beta.localserver');
        localStore = localServer.openManagedStore(storeName);
        isServerAvailable();
        $("#separator").text(' | ');
        if (!localStore) {
                localStore = localServer.createManagedStore(storeName);
                localStore.manifestUrl = manifestName;
                localStore.onerror = $('#offline').text('Error con el cache');
                localStore.oncomplete = $('#offline').text('Cache activado');
                localStore.onprogress = $('#offline').text(Math.ceil(((event.filesComplete / event.filesTotal) * 100)) + "%");
                localStore.checkForUpdate();
        }
        else {
            $('#offline').text('Cache activado');
        }
    }
});

ただし、localStore.onerror は常にトリガーされます。

質問があります:

  • 何がうまくいかないのですか?
  • 実際のエラーを確認するにはどうすればよいですか ( alert(localStore.onerror) は機能しません)

よろしく、

4

1 に答える 1

2

試す

if (!localStore) {
   localStore = localServer.createManagedStore(storeName);
   localStore.manifestUrl = manifestName;
   localStore.onerror = function(){$('#offline').text('Error con el cache');}
   localStore.oncomplete = function(){$('#offline').text('Cache activado');}
   localStore.onprogress = function(){$('#offline').text(Math.ceil(((event.filesComplete / event.filesTotal) * 100)) + "%");}
   localStore.checkForUpdate();
}

定義されたイベントで呼び出される関数への参照を割り当てる必要があります。あなたがしたことはこれらの関数を呼び出すことでした、そして最後にonerror、oncomplete、onprogressプロパティは$('#offline')。text('...')によって返されるjQueryインスタンスを保持しました

于 2009-05-05T16:00:02.063 に答える