
HTML5 Application Cache,也就是我们常说的AppCache,它主要用于让Web应用离线可用,通过一个清单文件(manifest file)声明哪些资源需要缓存,从而在用户没有网络连接时也能访问这些预先缓存的页面和资源。它的核心机制就是这个清单文件,浏览器会根据它来决定哪些文件应该被存储在本地,哪些应该始终从网络获取,以及哪些是备用资源。
要使用AppCache,你需要创建一个
.appcache
<html>
CACHE:
NETWORK:
FALLBACK:
1. 创建清单文件(例如:cache.appcache
CACHE MANIFEST # 版本号,每次更新清单文件时都需要改变,哪怕只是一个注释,否则浏览器不会重新下载 # v1.0.1 - 2023-10-27 # CACHE: 列出需要离线缓存的静态资源 CACHE: /index.html /css/style.css /js/main.js /images/logo.png # NETWORK: 列出永远需要从网络获取的资源,或者不应该被缓存的资源 # 即使离线,浏览器也会尝试访问这些资源,失败则报错 NETWORK: /api/data.json * # 星号表示所有未在CACHE或FALLBACK中声明的资源都应从网络获取 # FALLBACK: 当某个资源无法从网络获取时,提供一个备用资源 # 格式是:网络资源路径 备用资源路径 FALLBACK: /offline.html /offline.html / /offline.html # 任何未匹配的路径都重定向到离线页面
2. 在HTML文件中引用清单文件
立即学习“前端免费学习笔记(深入)”;
在你的
<html>
manifest
<!DOCTYPE html>
<html manifest="cache.appcache">
<head>
<title>我的离线应用</title>
<link rel="stylesheet" href="/css/style.css">
</head>
<body>
<h1>欢迎来到离线世界!</h1>
<img src="/images/logo.png" alt="Logo">
<script src="/js/main.js"></script>
</body>
</html>3. 服务器配置
确保你的Web服务器为
.appcache
text/cache-manifest
4. 更新机制
AppCache的更新机制有点“笨拙”。当你修改了任何缓存资源(比如
style.css
cache.appcache
我个人觉得,要真正理解AppCache,它的工作原理和生命周期是绕不开的。它不像我们现在用的Service Worker那么灵活,AppCache更像一个“一次性”的缓存策略。
当浏览器首次加载一个带有
manifest
GStreamer是一个非常强大而且通用的流媒体应用程序框架。GStreamer 所具备的很多优点来源于其框架的模块化: GStreamer 能够无缝的合并新的插件。但是, 由于追求模块化和高效率,,使得GStreamer 在整个框架上变的复杂, 也同时因为复杂度的提高, 使得开发一个新的应用程序显得不是那么的简单。 这个指南试图帮助你了解GStreamer 的框架(version 0.10.3.1)以方便你在GStreamer 框架的基础上做开发。第一章节将重点关注如何开发一个简单的音频播放器, 通过
0
cache.appcache
CACHE:
更新周期:
这才是AppCache最让人头疼的地方。
manifest
cache.appcache
updateready
updateready
applicationCache.swapCache()
location.reload()
所以,很多时候用户会觉得“我的更新怎么没生效?”就是因为这个两步走的激活过程,用户往往需要手动刷新两次。
老实说,我在项目里用AppCache的时候,踩过的坑可不少,它真的没有Service Worker那么友好。
cache.appcache
manifest="cache.appcache?v=123"
.appcache
NETWORK:
NETWORK: *
CACHE:
FALLBACK:
FALLBACK:
FALLBACK:
坦白讲,AppCache在设计上有一些固有的缺陷,加上其复杂的更新机制和调试难度,导致它在实际应用中经常让人抓狂。所以,现在前端社区普遍不推荐使用AppCache,它甚至已经被Web标准废弃了。
主要原因有:
更好的替代方案:Service Worker
毫无疑问,Service Worker 是AppCache的完美继任者,也是现代Web应用实现离线能力和高性能的关键技术。
Service Worker 本质上是一个在浏览器后台运行的JavaScript文件,它充当了Web应用和网络之间的代理。它能拦截所有的网络请求,并决定如何响应这些请求。这带来了巨大的灵活性和控制力:
install
activate
fetch
虽然Service Worker的学习曲线比AppCache陡峭一些,但它提供的强大功能和灵活性,绝对值得投入时间去学习和掌握。现在几乎所有的渐进式Web应用(PWA)都离不开Service Worker。
以上就是HTML5应用程序缓存怎么用_ApplicationCache应用指南的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号