返回顶部
首页 > 资讯 > 前端开发 > html >HTML5应用程序如何缓存Application Cache
  • 786
分享到

HTML5应用程序如何缓存Application Cache

2024-04-02 19:04:59 786人浏览 八月长安
摘要

HTML5应用程序如何缓存Application Cache,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是Applica

HTML5应用程序如何缓存Application Cache,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

什么是Application Cache

html5引入了应用程序缓存技术,意味着WEB应用可进行缓存,并在没有网络的情况下使用,通过创建cache manifest文件,可以轻松的创建离线应用。

Application Cache带来的三个优势是:

① 离线浏览

② 提升页面载入速度

③ 降低服务器压力

而且主要浏览器皆以支持Application Cache,就算不支持也不会对程序造成什么影响

离线存储技术

HTML5提出了两大离线存储技术:localstorage与Application Cache,两者各有应用场景;传统还有离线存储技术为Cookie。

经过实践我们任务localstorage应该存储一些非关键性ajax数据,做锦上添花的事情;

Application Cache用于存储静态资源,仍然是干锦上添花的事情;

而cookie只能保存一小段文本(4096字节);所以不能存储大数据,这是cookie与上述缓存技术的差异之一,而因为Http是无状态的, 服务器为了区分请求是否来源于同一个服务器,需要一个标识字符串,而这个任务就是cookie完成的,这一段文本每次都会在服务器与浏览器之间传递,以验 证用户的权限。

所以Application Cache的应用场景不一样,所以使用也不一致。

Application Cache简介

Application Cache的使用要做两方面的工作:

① 服务器端需要维护一个manifest清单

② 浏览器上只需要一个简单的设置即可

<html  manifest="demo.appcache">

以例子做说明:

CACHE MANIFEST

CACHE:
# 需要缓存的列表
style1.CSS1.jpg01.js
http://localhost/applicationcache/02.jshttp://localhost/applicationcache/zepto.jsNETWORK:
# 不需要缓存的4.jpg

FALLBACK:
# 访问缓存失败后,备用访问的资源,***个是访问源,第二个是替换文件*.html /offline.html
2.jpg/3.jpg

首先我这里报了一个错:

 Application Cache Error event: Manifest fetch failed (404)

这个错误的原因是:manifest 文件需要配置正确的 MIME-type,即 "text/cache-manifest"。必须在 web 服务器上进行配置,不同的服务器不一样

HTML5应用程序如何缓存Application Cache

\APPLICATIONCACHE01.js02.js1.jpg2.jpg3.jpg4.jpg
    demo.appcache
    index.html
    style1.css
    style2.css
    web.config
    zepto.js

这样一来便可以离线应用了,这个时候就算断网了,那些文件依旧能访问

HTML5应用程序如何缓存Application Cache

这里有一点值得注意,比如这里不带/index.html他会将“applicationcache/”缓存,其实这个就是index.html

manifest 文件可分为三个部分:
CACHE MANIFEST - 在此标题下列出的文件将在***下载后进行缓存
NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存
FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)

HTML5应用程序如何缓存Application Cache

如图所示,HTML5定义了几个事件点,但是我们一般不会主动使用js去操作什么,大多数情况下,我们完全依赖浏览器的处理即可。

尺寸限制

Application Cache的尺寸限制统一在5M,我这里做一个测试

HTML5应用程序如何缓存Application Cache

如所示,两个css文件依旧超过了5M这个时候

Document was loaded from Application Cache with manifest http://localhost/applicationcache/demo.appcacheindex.html:1 Application Cache Checking event
index.html:6 GET http://localhost/applicationcache/style2.css net::ERR_FAILEDindex.html:1 Application Cache NoUpdate event
index.html:11 GET http://localhost/applicationcache/2.jpg net::ERR_FAILEDindex.html:12 GET http://localhost/applicationcache/3.jpg net::ERR_FAILED

如所示,style2已经不能缓存了,这个会造成什么问题呢?

比如我A频道维护了自己的Application Cache,B频道也维护了自己的,这个时候A频道如果使用达到了一个峰值,会导致B频道所有的缓存失效,所以:

建议Application Cache,存储公共资源,不要存储业务资源

一些问题

由更新机制来说,***更新manifest时,因为页面加载已经开始 甚至已经完成,缓存更新尚未完成,浏览器仍然会使用过期的资源;浏览器是当Application Cache有更新时,该次不会使用新资源,第二次才会使用。这个时候update事件中执行window.reload事件。

window.applicationCache.addEventListener("updateready", function(){
    window.location.reload()
});

由上例可以知道,缓存的不只是显示定义的文件,比如上例中的 applicationcache/时便会默认保存index.html为映射的数据,并且包含demo.appcache文件,很多时候会遇到一次文件 更新线上老是不更新,这个时候随便在manifest配置文件中做一点修改即可更新。

比如我们将这里代码做一个改变:

<html  manifest="demo.appcache">=><html  manifest="demo1.appcache">

这个时候如果不做demo.appcache的更新的话,缓存将不会更新,原因是index.html被缓存了,检测的仍然是原manifest清单

各个页面统一管理自己的manifest清单,意思是a页面配置了common.js,b页面也配置了common.js,意思是a页面更新后,b页面的manifest不更改的话,b页面依旧读取的是老版本的文件,这个有一定道理却也有一定浪费,需要公共页面做处理。 

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网html频道,感谢您对编程网的支持。

--结束END--

本文标题: HTML5应用程序如何缓存Application Cache

本文链接: https://lsjlt.com/news/83050.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • HTML5应用程序如何缓存Application Cache
    HTML5应用程序如何缓存Application Cache,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。什么是Applica...
    99+
    2024-04-02
  • HTML5如何实现应用程序缓存
    本篇内容主要讲解“HTML5如何实现应用程序缓存”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML5如何实现应用程序缓存”吧!...
    99+
    2024-04-02
  • HTML5怎么实现应用程序缓存
    这篇文章主要介绍HTML5怎么实现应用程序缓存,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!为什么要使用Application Cache技术?在HTML5之前,我们需要接入网络才能访问,这毫无疑问是网站多次请求服务...
    99+
    2023-06-09
  • 怎么在Html5中实现应用程序缓存
    这篇文章给大家介绍怎么在Html5中实现应用程序缓存,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、作用离线浏览 - 根据文件规则把资源缓存在本地,脱机依然能够访问资源,联网会直接使用缓存在本地的文件。优化加载速度,...
    99+
    2023-06-09
  • Springboot如何集成spring cache缓存
    这篇“Springboot如何集成spring cache缓存”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Spr...
    99+
    2023-06-30
  • 如何解决Application Cache未缓存文件无法访问无法加载问题
    这篇文章主要介绍“如何解决Application Cache未缓存文件无法访问无法加载问题”,在日常操作中,相信很多人在如何解决Application Cache未缓存文件无法访问无法加载问题问题上存在疑惑...
    99+
    2024-04-02
  • 如何利用缓存来优化HTML5 Canvas程序的性能
    这篇文章主要介绍“如何利用缓存来优化HTML5 Canvas程序的性能”,在日常操作中,相信很多人在如何利用缓存来优化HTML5 Canvas程序的性能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2024-04-02
  • 如何在Go应用程序中使用NPM缓存?
    当我们在编写使用 Node.js 的 Go 应用程序时,经常会用到 NPM 包管理器来安装、更新和管理依赖项。但是,在使用 NPM 过程中,我们可能会遇到一些问题,例如网络连接较慢、依赖项版本更新导致构建失败等等。为了解决这些问题,我们可以...
    99+
    2023-10-07
    npm 缓存 load
  • HTML5中Web缓存和运用程序缓存的示例分析
    这篇文章主要为大家展示了“HTML5中Web缓存和运用程序缓存的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“HTML5中Web缓存和运用程序缓存的示例...
    99+
    2024-04-02
  • 在springboot使用spring 如何实现缓存cache
    本篇文章为大家展示了在springboot使用spring 如何实现缓存cache,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。声明式缓存Spring 定义 CacheManager 和 Cache...
    99+
    2023-05-31
    springboot spring cache
  • html5的offlline缓存如何使用
    这篇文章主要介绍了html5的offlline缓存如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇html5的offlline缓存如何使用文章都会有所收获,下面我们一起来...
    99+
    2024-04-02
  • Java应用程序如何正确处理路径缓存?
    在Java应用程序中,路径缓存是一个非常重要的概念。路径缓存可以提高应用程序的性能,并减少对文件系统的访问次数。但是,如果不正确处理路径缓存,就会导致应用程序出现问题,例如读取到错误的文件。 在本文中,我们将讨论Java应用程序如何正确处...
    99+
    2023-07-29
    path 缓存 apache
  • Java应用程序如何利用Shell脚本优化缓存?
    在Java应用程序中,缓存是非常重要的。缓存可以提高应用程序的性能,减少网络延迟和IO操作。然而,缓存也会占用大量的内存,导致应用程序变慢。为了解决这个问题,我们可以使用Shell脚本来优化缓存。本文将介绍如何使用Shell脚本来优化缓存...
    99+
    2023-09-06
    shell 缓存 git
  • 如何利用缓存提高ASP应用程序的性能?
    ASP应用程序的性能对于网站的用户体验至关重要。如果您的网站响应速度很慢,那么访问者可能会失去耐心并转向其他网站。因此,优化ASP应用程序的性能至关重要。本文将介绍如何使用缓存来提高ASP应用程序的性能。 一、什么是缓存? 缓存是一种将数据...
    99+
    2023-07-27
    缓存 shell 异步编程
  • HTML5中的manifest缓存如何使用
    本文小编为大家详细介绍“HTML5中的manifest缓存如何使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“HTML5中的manifest缓存如何使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深...
    99+
    2024-04-02
  • html5的离线缓存如何使用
    这篇文章主要介绍“html5的离线缓存如何使用”,在日常操作中,相信很多人在html5的离线缓存如何使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”html5的离线缓存如何...
    99+
    2024-04-02
  • 使用Spring如何实现注解Cache与Redis缓存
    使用Spring如何实现注解Cache与Redis缓存?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1. redis 和 ehcache的区别:简单了解了下,个人觉得 从部署上...
    99+
    2023-05-31
    spring redis 缓存
  • 如何用ThinkPHP缓存设置提升应用程序的性能
    这篇文章主要介绍“如何用ThinkPHP缓存设置提升应用程序的性能”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何用ThinkPHP缓存设置提升应用程序的性能”文章能帮助大家解决问题。一、缓存的优...
    99+
    2023-07-06
  • Java 缓存分布式教程:如何优化您的应用程序?
    随着互联网的不断发展,应用程序的高并发和大数据处理成为了每个开发者需要解决的问题。而缓存机制作为提高应用程序性能的一种重要方式,已经被广泛应用于各种应用场景中。在分布式应用程序中,缓存的作用更是不可忽视。本篇文章将介绍如何使用 Java ...
    99+
    2023-09-30
    缓存 分布式 教程
  • ASP缓存和Django函数:如何使用缓存来改善您的Web应用程序的响应时间?
    Web应用程序的响应时间是用户体验的重要组成部分。对于许多Web应用程序来说,缓存是提高响应时间的一种有效方式。在本文中,我们将探讨ASP缓存和Django函数,以及如何使用它们来改善Web应用程序的响应时间。 ASP缓存 ASP缓存是一...
    99+
    2023-06-15
    缓存 django 函数
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作