我刚刚在 iPad 上使用新的 iOS 6 发现了一些奇怪的行为。我正在测试一个网络应用程序以供离线使用。Web 应用程序只不过是一个带有缓存清单的静态网站,因此没有使用像 sencha touch 这样的特殊框架或像 phnoegap 这样的工具。只是 HTML、CSS 和 JavaScript 以及一个 cache.manifest。
该应用程序之前运行良好:我可以将网站保存到主屏幕。当我从那里打开它时,所有数据都将被下载以进行缓存。在下载结束时,弹出窗口会询问我是否要将缓存增加到 50MB - 接受 - 一切都很好 - 离线使用有效。
现在更新到 iOS 6 后:我对应用程序进行了一些更改。从主屏幕卸载应用程序。在移动 Safari 中再次打开它。保存到主屏幕。当打开下载按预期开始。但随后它冻结在 99%。当我在控制台中查找它时,我收到错误消息:“应用程序缓存更新失败,因为超出了大小配额。”
奇怪的事情来了:当我在浏览器中打开它时,下载开始,最后我被问到是否要将缓存大小增加到 50MB。我当然确认。当我现在在“网站数据”中查看 safari 的首选项时,我看到这个应用程序的所有缓存数据大约是 33MB!所以根本不超过50MB!
这是iOS6的错误吗?自 iOS 6 更新以来,在将网站保存到主屏幕时,是否有人遇到过缓存数据问题?感谢您的帮助,因为我真的被困在这里......在网上找不到任何有用的东西......
(不幸的是,我无法发布任何指向网络应用程序和/或其文件的链接)。
编辑:
我发现了有关此问题的更多信息:
http://www.nsbasic.com/blog/?p=928
显然,保存到主屏幕的 wep-apps 现在被视为原生应用程序,这意味着保存到主屏幕的同一 Web 应用程序的每个实例都有自己的“存储沙箱”。因此数据独立于移动 Safari 中保存的数据。这意味着如果您删除所有移动 safari 的网站数据,这对保存到主屏幕的网络应用程序没有影响(在 ios6 之前,它们共享相同的数据)。
我还发现了这个:
iOS 6 破坏了 webapps 中的 GeoLocation (apple-mobile-web-app-capable)
虽然不是完全相同的主题,但它可能是相关的。显然网络应用程序使用保存到主屏幕
<meta content="yes" name="apple-mobile-web-app-capable" />
将无法使用地理位置。仅当您从 Web 应用程序中删除此元标记时,地理位置才有效。也许这也是缓存问题的解决方法,我还不能测试它。但话又说回来:如果将保存到主屏幕的 Web 应用程序更像原生应用程序处理,也许不再需要 cache.manifest?如果我发现更多,我会在这里报告。
编辑2:
好的,经过一些测试并且没有来自网络和苹果的有用提示,我至少发现了一些东西:当我删除
<meta content="yes" name="apple-mobile-web-app-capable" />
从网站上看,一切都很好,因为就像你打开 Safari 一样,到目前为止我没有任何问题。所以我的兴趣是让它在没有浏览器 chrome 的情况下工作。如上所述,缓存仅达到 99%,然后我得到缓存大小配额超出错误。然后我只是关闭了主屏幕应用程序并再次打开它。现在缓存下载重新开始,完成就好了!没有冻结,没有错误!一切似乎都存储在本地。我今天只能在 iPad 模拟器上测试它,但我希望我能在稍后拿到我们的设备后尽快确认这一点。
因此,似乎不是被问到是否要增加缓存大小,而是得到缓存大小配额超出错误。也许是因为现在主屏幕应用程序的数据存储处理方式不同,您不必再手动增加缓存大小(这当然是纯粹的猜测)。不过,如果是这样的话,应该不会有任何错误。因此,您不必被要求增加缓存大小,而是必须打开主屏幕应用程序两次,顺便说一句,这是一个相当蹩脚的解决方法......
编辑3:
我只能在真实设备上确认此行为:保存到主屏幕->从主屏幕打开->下载到缓存文件->缓存大小配额最后超出错误->关闭主屏幕应用程序(按主页按钮)- > 再次重新打开它 -> 再次下载缓存文件 -> 这次没有错误 -> 一切都可以离线使用。
我还在一台装有 iOS 5 的设备上对其进行了测试,它可以正常工作,没有错误。所以这绝对是 iOS 6 的问题。
其他人可以确认这种行为或错误吗?
编辑4:
我偶尔有机会在 iOS 6.1.3 上对此进行测试——不幸的是仍然是相同的行为......