4

当 cache.manifest 已下载 html5 应用程序中的所有文件时,如何提醒成功消息?(基本上完成缓存下载的成功警报)!

谢谢

4

2 回答 2

2

非常感谢来自 Garden Gnome http://gardengnomesoftware.com/wiki/Cache_Manifest_File的深思熟虑的文章

我找到了答案。您所要做的就是创建一个 div,它将通过将其添加到您的页面来显示缓存的状态:

<div id="cachestatus" style="position:fixed;left: 2px;top: 2px; width: 150px;height:18px;color: #ff0000;padding: 1px 3px; opacity:1; z-index:100; font-family:Arial, Helvetica, sans-serif; opacity:0.2;"></div>

并在此 div 之后添加以下 java 脚本:

<script type="text/javascript">

    var cacheStatus  = document.getElementById('cachestatus');
    cacheStatus.innerHTML="cache status";


    if (navigator.onLine) {
        window.applicationCache.addEventListener('updateready', function(e) {
            if (window.applicationCache.status == window.applicationCache.UPDATEREADY) {
                window.applicationCache.swapCache();
                cacheStatus.innerHTML="update ready!";
                if (confirm('A new version of this page is available. Reload?')) {
                    window.location.reload();
                }
            }
        }, false);
        window.applicationCache.addEventListener('cached', function(e) {cacheStatus.innerHTML="cache is ready!"; },false);
        window.applicationCache.addEventListener('noupdate', function(e) { cacheStatus.innerHTML="cache is up to date!"; },false);
        window.applicationCache.addEventListener('downloading', function(e) { cacheStatus.innerHTML="downloading..."; },false);
        window.applicationCache.addEventListener('error', function(e) { cacheStatus.innerHTML="error"; },false);
        window.applicationCache.update();
    } else {
        cacheStatus.innerHTML="offline";
    }
</script>  

缓存的状态将显示在 DIV 中。

于 2012-08-24T08:49:27.820 回答
0

您可以绑定到window.applicationCache对象中的各种事件。其中之一是updateready事件。

您还必须确保为用户正确重新加载任何缓存更新。请参阅以下涵盖应用程序缓存基础知识、其事件以及如何以编程方式处理更新的文章。

在处理 AppCache 时您应该参考的其他一些文章是:

于 2012-08-22T09:21:57.173 回答