Я считаю, что отладка автономных приложений HTML5 - это боль.Я обнаружил, что код из этой статьи помог мне понять, что случилось с моим приложением:
http://jonathanstark.com/blog/2009/09/27/debugging-html-5-offline-application-cache/
Отладка кэша автономных приложений HTML 5 от Jonathan Stark
Если вы хотите предоставить автономный доступ к вашему веб-приложению, кэш автономных приложений, доступный в HTML5, просто ужасен.Тем не менее, это гигантский PITA для отладки, особенно если вы все еще пытаетесь разобраться с ним.
Если вы боретесь с манифестом кэша, добавьте следующий JavaScript на свою главную страницу HTML и просмотритеВыведите на консоль, используя Firebug в Firefox или Отладка> Показать консоль ошибок в Safari.
Если у вас есть какие-либо вопросы, PLMK в комментариях.
HTH,
j
var cacheStatusValues = [];
cacheStatusValues[0] = 'uncached';
cacheStatusValues[1] = 'idle';
cacheStatusValues[2] = 'checking';
cacheStatusValues[3] = 'downloading';
cacheStatusValues[4] = 'updateready';
cacheStatusValues[5] = 'obsolete';
var cache = window.applicationCache;
cache.addEventListener('cached', logEvent, false);
cache.addEventListener('checking', logEvent, false);
cache.addEventListener('downloading', logEvent, false);
cache.addEventListener('error', logEvent, false);
cache.addEventListener('noupdate', logEvent, false);
cache.addEventListener('obsolete', logEvent, false);
cache.addEventListener('progress', logEvent, false);
cache.addEventListener('updateready', logEvent, false);
function logEvent(e) {
var online, status, type, message;
online = (navigator.onLine) ? 'yes' : 'no';
status = cacheStatusValues[cache.status];
type = e.type;
message = 'online: ' + online;
message+= ', event: ' + type;
message+= ', status: ' + status;
if (type == 'error' && navigator.onLine) {
message+= ' (prolly a syntax error in manifest)';
}
console.log(message);
}
window.applicationCache.addEventListener(
'updateready',
function(){
window.applicationCache.swapCache();
console.log('swap cache has been called');
},
false
);
setInterval(function(){cache.update()}, 10000);