09-HTML5详解(三)

#Web 存储

随着互联网的快速发展,基于网页的应用越来越普遍,同时也变的越来越复杂,为了满足各种各样的需求,会经常性在本地存储大量的数据,传统方式我们以document.cookie来进行存储的,但是由于其存储大小只有4k左右,并且解析也相当的复杂,给开发带来诸多不便,HTML5规范则提出解决方案。

#H5 中有两种存储的方式

1、window.sessionStorage 会话存储:

  • 保存在内存中。

  • 生命周期为关闭浏览器窗口。也就是说,当窗口关闭时数据销毁。

  • 在同一个窗口下数据可以共享。

2、window.localStorage 本地存储:

  • 有可能保存在浏览器内存里,有可能在硬盘里。

  • 永久生效,除非手动删除(比如清理垃圾的时候)。

  • 可以多窗口共享。

#Web 存储的特性

(1)设置、读取方便。

(2)容量较大,sessionStorage 约5M、localStorage 约20M。

(3)只能存储字符串,可以将对象 JSON.stringify() 编码后存储。

#常见 API

设置存储内容:

  1. setItem(key, value);
 

PS:可以新增一个 item,也可以更新一个 item。

读取存储内容:

  1. getItem(key);
 

根据键,删除存储内容:

  1. removeItem(key);
 

清空所有存储内容:

  1. clear();
 

根据索引值来获取存储内容:

  1. key(n);
 

sessionStorage 的 API 举例:

  1. <!DOCTYPE html>
  2. <html>
  3. <head lang="en">
  4. <meta charset="UTF-8">
  5. <title></title>
  6. </head>
  7. <body>
  8. <input type="text"/>
  9. <button>sesssionStorage存储</button>
  10. <button>sesssionStorage获取</button>
  11. <button>sesssionStorage更新</button>
  12. <button>sesssionStorage删除</button>
  13. <button>sesssionStorage清除</button>
  14. <script>
  15. //在h5中提供两种web存储方式
  16. // sessionStorage session(会话,会议) 5M 当窗口关闭是数据销毁 内存
  17. // localStorage 20M 永久生效 ,除非手动删除 清理垃圾 硬盘上
  18. var txt = document.querySelector('input');
  19. var btns = document.querySelectorAll('button');
  20. // sessionStorage存储数据
  21. btns[0].onclick = function () {
  22. window.sessionStorage.setItem('userName', txt.value);
  23. window.sessionStorage.setItem('pwd', '123456');
  24. window.sessionStorage.setItem('age', 18);
  25. }
  26. // sessionStorage获取数据
  27. btns[1].onclick = function () {
  28. txt.value = window.sessionStorage.getItem('userName');
  29. }
  30. // sessionStorage更新数据
  31. btns[2].onclick = function () {
  32. window.sessionStorage.setItem('userName', txt.value);
  33. }
  34. // sessionStorage删除数据
  35. btns[3].onclick = function () {
  36. window.sessionStorage.removeItem('userName');
  37. }
  38. // sessionStorage清空数据
  39. btns[4].onclick = function () {
  40. window.sessionStorage.clear();
  41. }
  42. </script>
  43. </body>
  44. </html>
 

效果如下:

如上图所示,我们可以在 Storage 选项卡中查看 Session Storage 和Local Storage。

localStorage 的 API 举例:

  1. <!DOCTYPE html>
  2. <html>
  3. <head lang="en">
  4. <meta charset="UTF-8">
  5. <title></title>
  6. </head>
  7. <body>
  8. <input type="text"/>
  9. <button>localStorage存储</button>
  10. <button>localStorage获取</button>
  11. <button>localStorage更新</button>
  12. <button>localStorage删除</button>
  13. <button>localStorage清除</button>
  14. <script>
  15. /*
  16. * localStorage
  17. * 数据存在硬盘上
  18. * 永久生效
  19. * 20M
  20. * */
  21. var txt = document.querySelector('input');
  22. var btns = document.querySelectorAll('button');
  23. // localStorage存储数据
  24. btns[0].onclick = function () {
  25. window.localStorage.setItem('userName', txt.value);
  26. }
  27. // localStorage存储数据
  28. btns[1].onclick = function () {
  29. txt.value = window.localStorage.getItem('userName');
  30. }
  31. // localStorage删除数据
  32. btns[3].onclick = function () {
  33. window.localStorage.removeItem('userName');
  34. }
  35. </script>
  36. </body>
  37. </html>
 

#案例:记住用户名和密码

代码:

  1. <!DOCTYPE html>
  2. <html>
  3. <head lang="en">
  4. <meta charset="UTF-8">
  5. <title></title>
  6. </head>
  7. <body>
  8. <label for="">
  9. 用户名:<input type="text" class="userName"/>
  10. </label>
  11. <br/><br/>
  12. <label for="">
  13. 密 码:<input type="text" class="pwd"/>
  14. </label>
  15. <br/><br/>
  16. <label for="">
  17. <input type="checkbox" class="check" id=""/>记住密码
  18. </label>
  19. <br/><br/>
  20. <button>登录</button>
  21. <script>
  22. var userName = document.querySelector('.userName');
  23. var pwd = document.querySelector('.pwd');
  24. var chk = document.querySelector('.check');
  25. var btn = document.querySelector('button');
  26. // 当点击登录的时候 如果勾选“记住密码”,就存储密码;否则就清除密码
  27. btn.onclick = function () {
  28. if (chk.checked) {
  29. // 记住数据
  30. window.localStorage.setItem('userName', userName.value);
  31. window.localStorage.setItem('pwd', pwd.value);
  32. } else {
  33. // 清除数据
  34. window.localStorage.removeItem('userName');
  35. window.localStorage.removeItem('pwd');
  36. }
  37. }
  38. // 下次登录时,如果记录的有数据,就直接填充
  39. window.onload = function () {
  40. userName.value = window.localStorage.getItem('userName');
  41. pwd.value = window.localStorage.getItem('pwd');
  42. }
  43. </script>
  44. </body>
  45. </html>
 

#网络状态

我们可以通过 window.onLine 来检测用户当前的网络状况,返回一个布尔值。另外:

  • window.online:用户网络连接时被调用。

  • window.offline:用户网络断开时被调用(拔掉网线或者禁用以太网)。

网络状态监听的代码举例:

  1. <!DOCTYPE html>
  2. <html>
  3. <head lang="en">
  4. <meta charset="UTF-8">
  5. <title></title>
  6. </head>
  7. <body>
  8. <script>
  9. window.addEventListener('online', function () {
  10. alert('网络连接建立!');
  11. });
  12. window.addEventListener('offline', function () {
  13. alert('网络连接断开!');
  14. })
  15. </script>
  16. </body>
  17. </html>
 

#应用缓存

HTML5中我们可以轻松的构建一个离线(无网络状态)应用,只需要创建一个 cache manifest 缓存清单文件。

#优势

1、可配置需要缓存的资源;

2、网络无连接应用仍可用;

3、本地读取缓存资源,提升访问速度,增强用户体验;

4、减少请求,缓解服务器负担。

#cache manifest 缓存清单文件

缓存清单文件中列出了浏览器应缓存,以供离线访问的资源。推荐使用 .appcache作为后缀名,另外还要添加MIME类型。

缓存清单文件里的内容怎样写:

(1)顶行写CACHE MANIFEST。

(2)CACHE: 换行 指定我们需要缓存的静态资源,如.css、image、js等。

(3)NETWORK: 换行 指定需要在线访问的资源,可使用通配符(也就是:不需要缓存的、必须在网络下面才能访问的资源)。

(4)FALLBACK: 换行 当被缓存的文件找不到时的备用资源(当访问不到某个资源时,自动由另外一个资源替换)。

格式举例1:

格式举例2:

  1. CACHE MANIFEST
  2. #要缓存的文件
  3. CACHE:
  4. images/img1.jpg
  5. images/img2.jpg
  6. #指定必须联网才能访问的文件
  7. NETWORK:
  8. images/img3.jpg
  9. images/img4.jpg
  10. #当前页面无法访问是回退的页面
  11. FALLBACK:
  12. 404.html
 

缓存清单文件怎么用:

(1)例如我们创建一个名为 demo.appcache的文件。例如:

demo.appcache:

  1. CACHE MANIFEST
  2. # 注释以#开头
  3. #下面是要缓存的文件
  4. CACHE:
  5. http://img.smyhvae.com/2016040101.jpg
 

(2)在需要应用缓存在页面的根元素(html)里,添加属性manifest="demo.appcache"。路径要保证正确。例如:

  1. <!DOCTYPE html>
  2. <html manifest="01.appcache">
  3. <head lang="en">
  4. <meta charset="UTF-8">
  5. <title></title>
  6. </head>
  7. <body>
  8. <img src="http://img.smyhvae.com/2016040101.jpg" alt=""/>
  9. </body>
  10. </html>

html 09-HTML5详解(三)的更多相关文章

  1. .NET DLL 保护措施详解(三)最终效果

    针对.NET DLL 保护措施详解所述思路完成最终的实现,以下为程序包下载地址 下载 注意: 运行环境为.net4.0,需要安装VS2015 C++可发行组件包vc_redist.x86.exe.然后 ...

  2. Android 之窗口小部件详解(三)  部分转载

    原文地址:http://blog.csdn.net/iefreer/article/details/4626274. (一) 应用程序窗口小部件App Widgets 应用程序窗口小部件(Widget ...

  3. WebSocket安卓客户端实现详解(三)–服务端主动通知

    WebSocket安卓客户端实现详解(三)–服务端主动通知 本篇依旧是接着上一篇继续扩展,还没看过之前博客的小伙伴,这里附上前几篇地址 WebSocket安卓客户端实现详解(一)–连接建立与重连 We ...

  4. logback -- 配置详解 -- 三 -- <encoder>

    附: logback.xml实例 logback -- 配置详解 -- 一 -- <configuration>及子节点 logback -- 配置详解 -- 二 -- <appen ...

  5. python设计模式之装饰器详解(三)

    python的装饰器使用是python语言一个非常重要的部分,装饰器是程序设计模式中装饰模式的具体化,python提供了特殊的语法糖可以非常方便的实现装饰模式. 系列文章 python设计模式之单例模 ...

  6. Python操作redis字符串(String)详解 (三)

    # -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1.SET 命令用于设置 ...

  7. pika详解(三)SelectConnection及其他Connection

    pika详解(三)SelectConnection及其他Connection   本文链接:https://blog.csdn.net/comprel/article/details/94661147 ...

  8. View绘制详解(三),扒一扒View的测量过程

    所有东西都是难者不会,会者不难,Android开发中有很多小伙伴觉得自定义View和事件分发或者Binder机制等是难点,其实不然,如果静下心来花点时间把这几个技术点都研究一遍,你会发现其实这些东西都 ...

  9. Android WebView 开发详解(三)

    转载请注明出处   http://blog.csdn.net/typename/article/details/40302351 powered by miechal zhao 概览 Android ...

  10. KeilC51使用详解 (三)

    C51强大功能及其高效率的重要体现之一在于其丰富的可直接调用的库函数,多使用库函数使程序代码简单,结构清晰,易于调试和维护,下面介绍C51的库函数系统. 第一节 本征库函数(intrinsic rou ...

随机推荐

  1. mysql学习——数据表基本操作1

    选择数据库 创建数据表 包括字段名和数据类型两部分 查看数据表 使用主键约束 主键又称主码,能够唯一的表示表中的一条记录,分为单字段主键与多字段联合主键 单字段主键 定义主键的两种方式: 1.在最后指 ...

  2. c# 调用Go 动态库

    [StructLayout(LayoutKind.Sequential)] public struct GoMem { public IntPtr data; public UInt64 len; p ...

  3. 在IDM上设置防止过度抓取网站信息

    在使用Internet Download Manager(IDM)下载器时,有时会发现IDM自带的抓取功能过于强大,以至于有时会抓取一些无效的链接.那么,该如何避免IDM的过度抓取呢? 图1:IDM的 ...

  4. gitlab private-token利用工具

    在渗透测试中,经常会遇到只获得gitlab PRIVATE-TOKEN的情况,而gitlab提供了一系列的api给我们通过这个token去访问gitlab. 所以做了个简单的gitlab工具,以供紧获 ...

  5. JavaSE 学习笔记08丨网络编程

    Chapter 14. 网络编程 14.1 计算机网络入门 当前节的知识点只是一个概述,更具体.详细的内容放在 计算机网络 中. 14.1.1 软件结构 C/S结构(Client/Server结构): ...

  6. Java基础教程——String类

    String类 Java程序中的所有字符串字面值(如 "abc" )都是String的实例 字符串是常量(因为 String 对象是不可变的,所以可以共享) 字符串的本质是字符数组 ...

  7. 使用Python切片赋值

    解释器下运行以下代码:list1 = [4,5,6,7,8,9] list1[2:5] = ['a','b','c']结果是:[4, 5, 'a', 'b', 'c', 9]

  8. 自动化运维工具之Puppet常用资源(一)

    前文我们聊到了puppet的架构,单机模型和master/agent模型的工作流程以及puppet的基础使用,回顾请参考https://www.cnblogs.com/qiuhom-1874/p/14 ...

  9. 抖音短视频爆火的背后到底是什么——如何快速的开发一个完整的直播app

    前言 今年移动直播行业的兴起,诞生了一大批网红,甚至明星也开始直播了,因此不得不跟上时代的步伐,由于第一次接触的原因,因此花了很多时间了解直播,今天我来教你从零开始搭建一个完整的直播app,希望能帮助 ...

  10. python之汉诺塔

    # -*- coding: utf-8 -*- def move(n, a, b, c): if n==1: print(a,'==>',c)#只有一块的时候直接从A到C即可 else: mov ...