当前位置:首页 » 文件管理 » html5禁止页面缓存

html5禁止页面缓存

发布时间: 2023-12-19 16:16:13

A. 如何不让html5 app cache的manifest缓存当前页面

anifest的目的是离线运行,如果宿主html文件不被manifest自动缓存的话,整个离线运行最基本的html都跑不起来。

实在要用manifest,就将宿主html文件也添加进manifest清单中,然后在每次侦测到清单内容更新完毕后,提示用户并reload一次页面就好了。

B. html5嵌入到app中,缓存如何去掉

Android的话可以使用webview缓存设置
webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);

这样webView就不会去加载缓存了,或者,每次退出时手动删除webView缓存,应用databases目录下有两个we

C. 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清单
② 浏览器上只需要一个简单的设置即可
#p#副标题#e#
以例子做说明:
CACHE MANIFEST
CACHE:
# 需要缓存的列表
style1.css
1.jpg
01.js

NETWORK:
# 不需要缓存的
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 服务器上进行配置,不同的服务器不一样
APPLICATIONCACHE
01.js
02.js
1.jpg
2.jpg
3.jpg
4.jpg
demo.appcache
index.html
style1.css
style2.css
web.config
zepto.js
这样一来便可以离线应用了,这个时候就算断网了,那些文件依旧能访问
这里有一点值得注意,比如这里不带/index.html他会将“applicationcache/”缓存,其实这个就是index.html
manifest 文件可薯哪槐分为三个部分:
CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存
NETWORK - 在此标题下列出的文件需要与服务器的连数友接,且不会被缓存
FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)
如图所示,HTML5定义了几个事件点,但是我们一般不会主动使用js去操作什么,大多数情况下,我们完全依赖浏览器的处理即可。
#p#副标题#e#
尺寸限制
Application Cache的尺寸限制统一在5M,我这里做一个测试:
如所示,两个css文件依旧超过了5M这个时候
Document was loaded from Application Cache with manifest
index.html:1 Application Cache Checking event
index.html:6 GET
index.html:1 Application Cache NoUpdate event
index.html:11 GET
index.html:12 GET
如所示,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配置文件中做一点修改即可更新。
从可用性与易用性来说,Application Cache是值得使用的,但是最好是做静态资源的缓存,真正要实现离线应用还得花更多的功夫呢!

D. 如何不让html5 app cache的manifest缓存当前页面

这应该跟每个浏览器的版本实现机制有关系。
chrome 版本 31.0.1650.63
测试结果:如果把js放在index.html的body底部,那么就可以实现clock.js的app cache,但是clock.css是不行的。
ff 版本 28.0
测试结果:只能实现cache.html本身的缓存。
所以目前看来当初的这种HACK机制,只是在某个浏览器的某个版本支持。类似的问题的答案在stackoverflow上也有。不过,在用APP CACHE开始之前,还是要三思为何要用。APP CACHE 的提出是为了打造离线应用,也就是说离线后,应用可以通过依赖本地缓存文件达到正常使用。
如果说非要不缓存当前页面,目前看起来只能通过AJAX来动态加载页面的动态内容来解决了。

E. html5新增了离线缓存机制这说法对吗

这个不算是 新增吧。

随着现代浏览器的推动,Flash放弃对移动端的支持,HTML5无疑成为当前Web前端炙手可热的话题。各大游戏开发商、App开发商纷纷投入人力进行研究和技术储备。相信不久的将来,HTML5会迎来一个快速发展和普及的春天。那么,HTML5这个新一代的标准,又给我们带来哪些缓存机制呢?

HTML5 之离线应用Manifest
我们知道,使用传统的技术,就算是对站点的资源都实施了比较好的缓存策略,但是在断网的情况下,是无法访问的,因为入口的HTML页面我们一般运维的考虑,不会对其进行缓存。HTML5的Cache Mainifest离线应用特性就能够帮助我们构建离线也能使用的站点,所有的资源都使用浏览器本地缓存,当然前提是要求在联网的情形下使用过一次站点。
如何实现离线访问特性
实现的步骤非常简单,主要3个步骤:
1)在服务器上添加MIME TYPE支,让服务器能够识别manifest后缀的文件
AddType text/cache-manifest manifest
2)创建一个后缀名为.manifest的文件,把需要缓存的文件按格式写在里面,并用注释行标注版本
CACHE MANIFEST
# 直接缓存的文件
CACHE:
Path/to/cache.js
# version:2012-03-20
3)给 <html> 标签加 manifest 属性,并引用manifest文件
具体可以参考:HTML5 缓存: cache manifest
<html manifest=”path/to/name-of.manifest”>
离线应用访问及更新流程
第一次访问离线应用的入口页HTML(引用了manifest文件),正常发送请求,获取manifest文件并在本地缓存,陆续拉取manifest中的需要缓存的文件
再次访问时,无法在线离线与否,都会直接从缓存中获取入口页HTML和其他缓存的文件进行展示。如果此时在线,浏览器会发送请求到服务器请求manifest文件,并与第一次访问的副本进行比对,如果发现版本不一致,会陆续发送请求重新拉取入口文件HTML和需要缓存的文件并更新本地缓存副本
之后的访问重复第2步的行为
离线机制的缓存用途
从Manifest的机制来看,即使我们不是为了创建离线应用,也同样可以使用这种机制用于缓存文件,可以说是给Web缓存提供多一种可以选择的途径。
存在的问题:缓存文件更新控制不灵活
就目前HTML5提供的manifest机制来讲,一个页面只能引用一个manifest页面,而且一旦发现这个manifest改变了,就会把里面所有定义的缓存文件全部重新拉取一遍,不管实际上有没有更新,控制比较不灵活。针对这个问题,也有的同学提出了一些建议,比如把需要缓存的文件分模块切分到不同manifest中,并分开用HTML引用,再使用强大的iframe嵌入到入口页面,这样就当某一个模式需要有更新,不会导致其他模块的文件也重新拉取一遍。

HTML5 之本地存储localstorage
HTML5给我们提供本地存储localstorage特性,严格来讲,其实已经不算传统Web缓存的范畴。因为它存储的地方是跟Web缓存分开的,是浏览器重新开辟的一个地方。
localstorage的作用
本地存储localstorage的作用主要使Web页面能够通过浏览器提供的set/get接口,存储一些自定义的信息到本地硬盘,并且在单次访问或以后的访问过程中随时获取或修改。
Localstorage的使用
Localstorage提供了几个非常易用的Api,setItem/getItem/removeItem/clear,具体的可以参考:Html5 Step by Step(二) 本地存储
Localstorage的缓存用途
Localstorage设计的本意可能是用来存储一些用户操作的个性化设置的文本类型的信息和数据,当我们其实也可能拿来当Web缓存区使用,比如我们可以将Base64格式编码的图片信息,存在localstorage中,再次访问时,直接本地获取后,使用Css3的Data:image的方式直接展现出来。
存在的问题:大小限制
按照目前标准,目前浏览器只给每个独立的域名提供5m的存储空间,当存储超过5m,浏览器就会弹出警告框。

可以说,HTML5的Manifest和localstorage是给我们在考虑Web缓存的时候提供了多一种思路,当你开发的应用只面对现代浏览器的时候,不妨可以考虑一下

F. html5基本知识点

一、HTML的开发工具和使用的浏览器

开发工具:记事本等文本编辑器,Atom、VisualStudioCode( VSCode)、Brackets、Sublime text和Hbuider。

浏览器:Chrome、Firefox、IE、Safari、IPhone、Android。

二、HTML的基本要素

DOCTYPE 描述文档的类型

html 网页的根元素,写在网页的在外面

head 网页的头部信息,写在html标记的里面

body 网页的内容,写在html标记的里面

具体描述:

1、DOCTYPE 描述文档的类型,规定web 浏览器关于页面使用哪个 HTML 版本进行编写的指令。

网页可以使用的具体版本,网页中可以使用那些标记,每个版本的DTD版本均有不同

使用例子

HTML4的例子

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

HTML5的例子

(二)、title、base标记

title和base标记都是写在head标签中

title:设置网页的标题

写法:<title>内容</title>。

base:指定网页跳转基准URL,如果不指定的话默认为当前网站的当前路径。

写法:<base href="http://www.aaa.zzz/">

base属性值:

  • href 指定网页跳转到基准URL,如果不指定的话则默认为当前网站的当前路径。

  • <base href="http://.com/">这是将页面跳转到网络的网站打开。

  • target 指定链接的跳转帧如果不指定的话,则是在当前页面中跳转。

  • <base target="_blank">网页中的链接都应该在新的窗口中打开。

    terget属性值:

  • _blank 在新窗口中打开被链接的文档

  • _self 默认值,在相同框架中打开被链接的文档

  • _parent 在父框架集中

  • _top 在整个窗口中打开被链接文档·

  • framename 在指定框架中打开被链接文档

  • (三)、link标记

    link标记:链接外部文件时使用的标记,可以把外部文件的内容引入到当前文件中来,使当前网页实现更多的功能。

    link属性:

    href:指定链接外部路径的路径和文件名,要设置全路径并且带文件名

    rel:引用文件,引用资源的类型定义

    我们在使用link标签引用外部文件的时候,外部文件的类型是多种多样的。

    alternate 代替文档(种子,其他语言版本,其他格式等等)

    author 网页的作者

    help 帮助文件的链接

    icon 网页的图标

    next 如果是连续网页的时候,指定下一个网页

    prefetch 把链接外部资源时提前缓存起来。

    prev 如果是连续网页

    media 链接文件或是资源属于哪一种资源。

    hreflang 链接文件的语言种类

    type 链接文件的mi/me类型(比如说,图片图标文本)

    sizes 根据link链接文件的类型,来指定文件的大小

    代码示例:

    链接网页图标:

  • 网站的图标指定,可以显示在浏览器的图标栏,也可以被手机读取作为网站的图标存入收藏夹

  • 1 <!-- 网站的图标指定,可以显示在浏览器的图标栏,也可以被手机读取作为网站的图标存入收藏夹 -->2 <link rel="icon">3 <!-- 示例 -->4 <link rel="icon" href="img/favicon.png" type="image/png">5 <link rel="shortcut icon" href="img/favicon.ico" type="image/x-icon">6 <link rel="apple-touch-icon" href="img/apple-touch-icon.png" type="image/png">

  • 注意:后面的href和前面type标注的类型要一致,这样既可以显示在浏览器,又可以显示在手机上

    链接外部样式单

  • 1 <link rel="stylesheet">2 <link rel="stylesheet" href="style1.css" media="screen">3 <link rel="stylesheet" href="style2.css" title="主题样式文件">4 <link rel=" alternate stylesheet" href="style3.css" title="可选样式单">

  • 说明:

    alternate 会在浏览器中会弹出一个对话框,供用户可以进行选择

    media 表示媒体类型为屏幕,可以是手机,但不包括打印机和投影仪

    title 对这个link进行简单的说明

    网站RSS种子指定

  • <!-- 网站RSS种子指定 -->

  • <link rel="alternate" type="application/rss+xml">

  • 为搜索引擎的准备的网页的URL

  • <!-- 为搜索引擎的准备的网页的URL -->

  • <link rel="canonical">

  • <link rel="canonical" href="http://www.aaa.zzz/help.html">

  • G. html5缓存的问题,如何正确设置

    html5缓存正确的设置办法:

    1、启用缓存

    设置方法:
    <html manifest="example.appcache">
    ...
    </html>

    2、设定缓存访问的范围,配置到MANIFEST中:
    CACHE MANIFEST
    # v1 - 2011-08-13
    # This is a comment.
    http://www.example.com/index.html
    http://www.example.com/header.png
    http://www.example.com/blah/blah

    热点内容
    华山算法 发布:2025-01-21 08:44:48 浏览:366
    如何在微信上再设置一个密码 发布:2025-01-21 08:44:39 浏览:731
    浙江服务器搭建云主机 发布:2025-01-21 08:41:38 浏览:452
    光遇和王者荣耀哪个需要的配置高 发布:2025-01-21 08:40:28 浏览:13
    如何取消安卓微信表情 发布:2025-01-21 08:08:39 浏览:556
    python判断是否为字母 发布:2025-01-21 08:07:55 浏览:609
    安卓手机如何注销吃鸡账号并把钱拿回来 发布:2025-01-21 07:56:14 浏览:887
    电信的密码是什么意思 发布:2025-01-21 07:30:36 浏览:717
    在自己电脑搭建服务器 发布:2025-01-21 07:27:13 浏览:654
    怎么配置钉钉代理网络 发布:2025-01-21 07:17:16 浏览:711