html5应用缓存与Web Workers

简介:

HTML5当中引入了应用程序缓存,这意味着web应用可以进行缓存,并且可以在没有网络连接的时候进行访问。

应用缓存的优势

  • 离线浏览,用户可以在离线的时候浏览已经加载并且缓存好的数据

  • 加快加载速度。

  • 减少服务器负载。

实现用缓存

如果启用应用程序缓存,需要在<html>标签当中包含manifest属性,manifest文件的建议扩展名是:”.appcache”

manifest文件

manifest文件为我们提供了三种缓存的方式: 
version n.n :version表示当前manifest的版本,当version发生变化的时候,此时当用户再次加载的时候,会将CACHE标签下列出的所有文件重新下载一次。 
- CACHE MANIFEST:在此标题下列出的文件,将在首次下载后进行缓存。 
- NETWORK: 在此标题下列出的文件需要与服务器的链接,且不会被缓存。 
- FALLBACK: 在此标题下列出的文件,规定访问缓存失败后,备用访问的资源,第一个是访问源,第二个是替换文件*.html /offline.html,例如404页面。

缓存的应用

这里我创建一个web工程,并且新建一个html文件: 
index.html

<!DOCTYPE html><html manifest="index.appcache">   <head>     <title>index.html</title>     <link rel="stylesheet" type="text/css" href="./css/style.css">   </head>    <body>     <h1>This is my HTML page</h1>   </body></html>1234567891012345678910

style.css

@CHARSET "UTF-8";h1 {    color: aqua;}12341234

可以看到这里,我的页面很简单,并且引用了一个style.css样式文件。并且在<html>标签当中,指定了缓存文件index.appcache. 
index.appcache 内容如下:

CACHE MANIFEST#version 1.0CACHE:index.htmlcss/style.css1234512345

可以看到,这里我们使用CACHE类型的缓存,表示需要缓存index.html和css/style.css这两个文件。此时打开服务器,浏览该网页,在关闭服务器,会发现该网页同样可以访问,此时按下F12,打开开发者选项,会发现有如下缓存: 
这里写图片描述

同时也可以使用NETWORK类型的缓存,来表示那些文件是需要联网下载的,这里我将css/style.css文件写入到NETWORK类型的缓存当中。

CACHE MANIFEST#version 1.0CACHE:index.htmlNETWORK:css/style.css1234567812345678

首先需要手动清除一下之前缓存的记录。然后打开服务器,浏览http://localhost:8080/html5cache/index.html,此时显示效果如下: 
这里写图片描述 
可以看到此时只是缓存了html页面,并没有缓存css/style.css文件,此时关闭服务器,再次刷新该页面,效果如下: 
这里写图片描述 
可以看到此时,就只是加载了html页面,并么有加载css文件,所以h1标签的字体是默认的。

更新缓存

如果需要更新缓存,比如这里我更改了html中的文字,此时再次访问http://localhost:8080/html5cache/index.html 的时候,是不会加载最新的页面文字的,这是因为浏览器默认会到缓存中查找,如果缓存中有,则直接从缓存中取出,因此我们需要更新缓存文件”index.appcache”中的version即可,如下:

CACHE MANIFEST#version 1.1CACHE:css/style.cssindex.htmlNETWORK:FALLBACK:1234567891012345678910

这里,我将version更改了1.1,此时再次访问该页面的时候, 是会到服务其下载最新的页面,说到这里,缓存的缺点就出来了,就是哪怕我一个页面中只更新一行文字,但是当我更改了”index.appcache”文件中的version值之后,就会重新将CACHE中定义的所有内容,重新下载一次。

使用js自动更新缓存

另外,我们还可以使用applicationcache对象来自动更新缓存。如下:

<script type="text/javascript">          //添加页面加载函数         window.addEventListener('load', function(e) {           //为applicationCache对象添加updateready事件            window.applicationCache.addEventListener('updateready', function(e) {             //表示manifest中列举的文件已经重新下载并更新成功             if (window.applicationCache.status == window.applicationCache.UPDATEREADY) {              //使用swapCache()方法更新到应用程序中               window.applicationCache.swapCache();              if (confirm('A new version of this site is available. Load it?')) {                //重新加载当前页面                 window.location.reload();               }             } else {                //manifest文件没有变化                 console.log("manifest 没有改变");             }           }, false);         }, false);    </script>12345678910111213141516171819202122232425261234567891011121314151617181920212223242526

applicationcache是window对象的直接子对象,该对象的事件列表如下: 
这里写图片描述 
status 返回缓存的状态

可选值 匹配常量 描述
0 appCache.UNCACHED 未缓存
1 appCache.IDLE 闲置
2 appCache.CHECKING 检查中
3 appCache.DOWNLOADING 下载中
4 appCache.UPDATEREADY 已更新
5 appCache.OBSOLETE 失效

方法

方法名 匹配常量
update() 发起应用程序缓存下载进程
abort() 取消正在进行的缓存下载
swapcache() 切换成本地最新的缓存环境

web workers

web workers是运行在后台的脚本,独立于其他的脚本,不会影响页面的性能。类似于Android开发中的handler。将繁重耗时的计算放到web worker中来实现,然后将处理的结果返回给主UI线程来显示。

web workers方法

  • postMessage() :用于向html页面回传一段消息。

  • terminate() :终止web workers,并且释放计算机资源。

web workers简单实现

下面使用web workers简单实现一数字更新的demo: 
新建一个web工程,创建index.html

<!DOCTYPE html><html><head lang="en">     <meta charset="UTF-8">     <title></title>     <script src="index.js"></script></head><body>     <div id="numDiv">0</div></body></html>12345678910111234567891011

这里在index.html文件当中引入了index.js文件。 
index.js

var numDiv; window.onload = function(){     numDiv = document.getElementById("numDiv");    var work = new Worker("count.js");     work.onmessage = function(e) {         //alert(e.data);         numDiv.innerHTML = e.data;     }; };123456789123456789

可以看到,这里讲更新数据的具体操作,使用Worker来更新,在worker当中加载了count.js文件来做一些耗时,复杂的计算。然后使用worker的onmessage回调方法,将count.js返回的结果重新显示给numDiv。 
count.js

var countNum = 0;function count(){     postMessage(countNum);//通过postMessage方法将计算结果回传给调用者     countNum++;     setTimeout(count,1000); } count();12345671234567

count.js文件比较简单,每隔一秒更新countNum的值,然后回传给调用者,也就是这里的index.js

此时运行效果如下: 
这里写图片描述

下面添加一个开始停止的控制按钮:

 <button id="start">start</button>  <button id="stop">stop</button>1212

index.js

var numDiv;var work; window.onload = function(){     numDiv = document.getElementById("numDiv");    var start = document.getElementById("start");    var stop = document.getElementById("stop");     start.onclick = startWorker;     stop.onclick = stopWorker; };function startWorker() {     if (work) { //如果work存在,则直接返回         return;     } else {         work = new Worker("count.js");         work.onmessage = function(e) {             numDiv.innerHTML = e.data;         };     } }function stopWorker() {     if (work) {//如果worker存在,则终止并且为其重新赋值         work.terminate();         work = null;     } }1234567891011121314151617181920212223242526272812345678910111213141516171819202122232425262728

此时运行效果如下: 
这里写图片描述

另外我们还可以通过navaigator对象的onLine属性来判断当前浏览器是否在线,该属性属于只读属性,会返回boolean类型的值。

if(window.navigator.onLine) {    //在线} else {    //离线}1234512345

转载至:http://blog.csdn.net/mockingbirds/article/details/48412967

本文转自    风雨萧条 博客,原文链接:http://blog.51cto.com/1095221645/1900170        如需转载请自行联系原作者


相关文章
|
6月前
|
移动开发 JavaScript 前端开发
HTML5 Web Workers详解
HTML5 Web Workers 允许在后台线程中运行 JavaScript,实现复杂计算而不影响用户界面,提升应用性能。其主要特性包括并行处理、异步通信、独立作用域及多数据类型支持。通过创建和使用 Worker 文件,如 `worker.js`,可执行后台任务,并与主线程通过消息传递机制通信。适用于数据处理、图像处理、复杂计算及网络请求并行等场景。需要注意的是,Web Workers 在浏览器兼容性、安全性限制、调试及资源消耗方面需特别关注。合理利用 Web Workers 可显著增强 Web 应用的流畅度和响应速度。
|
8月前
|
前端开发 JavaScript 大数据
React与Web Workers:开启前端多线程时代的钥匙——深入探索计算密集型任务的优化策略与最佳实践
【8月更文挑战第31天】随着Web应用复杂性的提升,单线程JavaScript已难以胜任高计算量任务。Web Workers通过多线程编程解决了这一问题,使耗时任务独立运行而不阻塞主线程。结合React的组件化与虚拟DOM优势,可将大数据处理等任务交由Web Workers完成,确保UI流畅。最佳实践包括定义清晰接口、加强错误处理及合理评估任务特性。这一结合不仅提升了用户体验,更为前端开发带来多线程时代的全新可能。
216 1
|
8月前
|
移动开发 数据挖掘 API
HTML5 中 Web Workers API 的用法
【8月更文挑战第24天】
85 0
|
9月前
|
缓存 JavaScript 前端开发
Web Workers与Service Workers:后台处理与离线缓存
Web Workers 和 Service Workers 是两种在Web开发中处理后台任务和离线缓存的重要技术。它们在工作原理和用途上有显著区别。
114 1
|
9月前
|
缓存 JavaScript 前端开发
JavaScript进阶 - Web Workers与Service Worker
【7月更文挑战第4天】JavaScript的Web Workers和Service Worker增强了Web性能。Web Workers处理后台多线程,减轻主线程负担,但通信有开销,受同源策略限制。Service Worker则用于离线缓存和推送通知,需管理其生命周期、更新策略,并确保安全。两者都带来了挑战,但也极大提升了用户体验。通过理解和优化,开发者能构建更高效、安全的Web应用。
226 2
|
存储 分布式计算 资源调度
Hadoop运行模式(三)、群起集群、配置workers、启动集群、启动HDFS、拼接、Web端查看HDFS的NameNode、Web端查看YARN的ResourceManager
Hadoop运行模式(三)、群起集群、配置workers、启动集群、启动HDFS、拼接、Web端查看HDFS的NameNode、Web端查看YARN的ResourceManager
Hadoop运行模式(三)、群起集群、配置workers、启动集群、启动HDFS、拼接、Web端查看HDFS的NameNode、Web端查看YARN的ResourceManager
|
9月前
|
缓存 前端开发 JavaScript
JavaScript进阶 - Web Workers与Service Worker
【7月更文挑战第10天】在Web开发中,Web Workers和Service Worker提升性能。Workers运行后台任务,防止界面冻结。Web Workers处理计算密集型任务,Service Worker则缓存资源实现离线支持。常见问题包括通信故障、资源限制、注册错误及缓存更新。通过示例代码展示了两者用法,并强调生命周期管理和错误处理的重要性。善用这些技术,可构建高性能的Web应用。
239 0
|
9月前
|
缓存 JavaScript 前端开发
JavaScript进阶 - Web Workers与Service Worker
【7月更文挑战第6天】JavaScript的Web Workers和Service Worker增强了浏览器的性能处理和离线功能。Web Workers处理后台计算,减轻主线程压力,但通信有开销,受同源策略限制。Service Worker则能拦截网络请求,支持离线缓存和推送通知,但其生命周期和权限管理需谨慎处理。通过理解它们的工作原理和限制,开发者能创建更流畅、更健壮的Web应用。
321 0
|
11月前
|
JavaScript 前端开发 算法
Web Workers与WebAssembly初探
Web Workers和WebAssembly是提升Web应用性能的两种技术。Web Workers在后台线程运行JavaScript,避免阻塞主线程,适合处理耗时任务。WebAssembly则是一种二进制格式,可在浏览器中运行高性能计算,支持多种编程语言。两者结合,复杂计算可在后台线程用WebAssembly执行,提高应用响应速度。示例展示了如何在Web Worker中使用WebAssembly进行计算并返回结果。
|
11月前
|
移动开发 前端开发 数据处理
探索前端性能优化的新思路:使用Web Workers提升网页响应速度
传统的前端性能优化方法已经不能完全满足日益增长的网页需求。本文提出了一种新的思路,即利用Web Workers技术来提升网页的响应速度。通过将耗时的计算任务交给Web Workers处理,可以避免主线程阻塞,从而提高网页的用户体验。本文将介绍Web Workers的基本原理、使用方法以及在前端性能优化中的应用实例,帮助开发者更好地理解和运用这一技术。