在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
在介绍HTML5 web缓存前,来认识一下cookie和session: session: 由于HTTP是无状态的,你是谁?你干了什么?抱歉服务器都是不知道的。 因此session(会话)出现了,它会在服务器上存储用户信息以便将来使用(比如用户名称,购物车购买商品等)。 但是session是临时的,用户离开网站将被删除。如果要永久存储信息,可以保存在数据库中! session工作原理:为每个用户创建一个session id(核心!!!)。而session id是存储在cookie中的,也就是说如果浏览器禁用了cookie,那么session会失效!(但是可以通过其它方式实现,如:通过URL传递session id) 用户验证一般采用session。 cookie: 目的:网站标记用户身份而存储在本地客户端的数据(通常经过加密)。
cookie会在同源的http请求携带(即使不需要),即在客户端和服务器之间来回传递! cookie的数据大小不超过4k cookie的有效期:设置的cookie有效时间之前一直有效,即使浏览器关闭! localStorage & sessionStorage: 早期,本地缓存普遍使用的是cookie,但是web存储需要更安全、更快速! 这些数据不会保存在服务器上(存储在客户端),不会影响服务器性能! sessionStorage和localStorage数据存储也有大小限制,但却比cookie大得多,可以达到5M甚至更大! localStorage:没有时间限制的数据存储! sessionStorage:由英文意思也可知,它是对session的数据存储,所以在用户关闭浏览器(标签页/窗口)后,数据被删除! HTML5 web存储支持情况: IE8以上,现代浏览器。 数据以键值对存储: localStorage和sessionStorage都有以下几个方法:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>web storage</title> </head> <body> <div id="test"></div> <script> if (typeof (Storage) != undefined) { localStorage.name = 'xiao ming'; localStorage.setItem('name1', 'Apple'); document.getElementById('test').innerHTML = "you are: " + localStorage.name; console.log("first:" + localStorage.name1 + "," + localStorage.key(0)); localStorage.removeItem('name1'); console.log("second: " + localStorage.name1); console.log("third: " + localStorage.getItem('name')); localStorage.clear(); console.log("last:" + localStorage.name); } else { document.getElementById('test').innerHTML = "更新浏览器吧!目前浏览器不支持stroage"; } </script> </body> </html> 程序运行结果: 注意:键值对是以字符串保存的,根据需求应改变类型(比如做加法,变为Number型)。 HTML5运用程序缓存(Application Cache): 通过创建cache manifest文件,web运用可被缓存,并且无网络状态可以进行访问! Application Cache优势: 1.离线浏览; 支持情况: IE10以上,现代浏览器。 使用: <!DOCTYPE html> <html manifest="demo.appcache"> </html> 注意:要开启application cache,需指定manifest属性(扩展名:.appcache);如果未指定manifest属性,页面不会缓存(除非在manifest文件中直接指定了该页面!) manifest文件在服务器上需正确的配置MIME-type:text/cache-manifest。 Manifest文件: manifest是简单的文本文件,它告知浏览器被缓存的内容以及不被缓存的内容! manifest可分为三部分: CACHE MANIFEST:此项列出的文件将在首次下载后进行缓存! NETWORK:此项列出的文件需要与服务器进行网络连接,不会被缓存! FALLBACK:此项列出当页面无法访问时的回退页面(如:404页面)! test.appcache: CACHE MANIFEST #2017 11 21 v10.0.1 /test.css /logo.gif /main.js NETWORK /login.php /register.php FALLBACK #/html/目录中文件无法访问时,用/offline.html替代 /html/ /offline.html 更新application cache的情况: Web Workers: web workers是运行在后台的javascript,独立于其它脚本,不会影响页面性能! 而一般的HTML页面上执行脚本时,除非脚本加载完成,否则页面不会响应! 支持情况:IE10以上,现代浏览器 示例:html文件: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>web worker</title> </head> <body> <p>计数:<output id="count"></output></p> <button onclick="startWorker()">开始</button> <button onclick="overWorker()">结束</button> <script> var w; function startWorker(){ // 检测浏览器是否支持web worker if(typeof(Worker)!=='undefined'){ if(typeof(w)=='undefined'){ //创建web worker对象 w=new Worker('testWorker.js'); } // 事件持续监听(即使外部脚本已经完成),除非被终止 w.onmessage=function(event){ document.getElementById('count').innerHTML=event.data; }; }else{ document.getElementById('count').innerHTML='浏览器不支持web worker'; } } function overWorker() { // 终止web worker对象,释放浏览器/计算机资源 w.terminate(); w=undefined; } </script> </body> </html> testWorker.js文件: var i=0; function timedCount() { i+=1; // 重要的部分,向html页面传回一段信息 postMessage(i); setTimeout('timedCount()',500); } timedCount(); 注意1:通常web worker不是用于如此简单的任务,而是用在更耗CPU资源的任务! 注意2:在chrome中运行会产生“cannot be accessed from origin 'null'”的错误,我的解决方法是:xampp中开启apache,用http://localhost/进行访问。 web worker缺点: 由于web worker位于外部文件中,所以它无法访问下列javascript对象:
HTML5 server-sent events(服务器发送事件): server-sent事件是单向信息传递;网页可以自动获取来自服务器的更新! 以前:网页先询问是否有可用的更新,服务器发送数据,进行更新(双向数据传递)! 支持情况:除IE以外的现代浏览器均支持! 示例代码:html文件: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>sever sent event</title> </head> <body> <p>sever sent event informations</p> <div id="test"></div> <script> // 判断浏览器是否支持EventSource if(typeof(EventSource)!==undefined){ // 创建EventSource对象 var source=new EventSource("test.php"); // 事件监听 source.onmessage=function(event){ document.getElementById('test').innerHTML+=event.data+"<br>"; }; }else{ document.getElementById('test').innerHTML="sorry,浏览器不支持server sent event"; } </script> </body> </html> test.php: <?php header('Content-Type:text/event-stream'); header('Cache-Control:no-cache'); $time=date('r'); echo "data:The server time is: {$time} \n\n"; // 刷新输出数据 flush(); 注意:后面没有内容,php文件可以不用"?>"关闭! HTML5 WebSocket:
WebSocket如何兼容低浏览器:
WebSocket可以用在多个标签页之间的通信! 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持极客世界。 |
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论