1.离线应用 离线应用是 HTML 5 新增的以想功能,旨在帮助用户在没有网络的情况下,也可以使用 web 应用程序。
HTML 5 离线功能,包含【离线资源缓存】、【在线状态监测】、【本地数据存储】。 - 离线资源缓存 - 通过浏览器机制,将在线资源缓存到本地,当用户离线访问应用程序时,这些资源文件自动从本地加载,从而让用户可以正常的使用应用程序。
- 在线状态监测 - 有些应用需要跟服务器做一些数据的交互,应用开发者需要知道浏览器是否处于在线状态,HTML 5 提供了在线状态监测。(window.online = function(){})
- 本地数据存储 - 当应用程序处于离线状态时,程序需要把用户产生的数据存储到本地,以便于在线时同步到服务器上。为此,HTML 5 提供了多种本地存储机制。
离线 web 应用对比普通的 web 应用,多了一个描述文件,用于列出【需要缓存】和【永不缓存】的资源。该文件扩展名为【.appcache】,描述文件的 mime-type 类型为 “text/cache-manifest”。 offline.appcache 文件的代码如下 CACHE MANIFEST#cache 之后的资源都会被缓存CACHE:main.htmlstyle.cssmain.js#network 之后的资源不会被缓存,总是从线上获取NETWORK:account/如果离线化应用程序,只需将 .html 文件 和 manifest 描述文件关联起来即可 <html manifest="./offline.appcache"></html>2.LocalStorage 和 SessionStorage cookie 的弊端 - 大小受限 - 标准浏览器下,单个Cookie 的大小为 4kb。
- 消耗性能 - 当前域下的所有 http 请求都会携带这些 Cookie 数据。
HTML5 的本地存储为每个网站分配的空间时 【5MB】 LocalStorage 和 SessionStorage 的区别
前者会一直存储在本地,直到手动清除;
后者则存活在当前页面的生命周期中,一旦页面关闭,存储的数据也会消失。
|