cookie

Cookie 是小甜饼的意思。顾名思义,cookie 确实非常小,它的大小限制为4KB左右,是网景公司的前雇员 Lou Montulli 在1993年3月的发明。它的主要用途有保存登录信息,比如你登录某个网站市场可以看到“记住密码”,这通常就是通过在 Cookie 中存入一段辨别用户身份的数据来实现的。

localStorage

localStorage 是 HTML5 标准中新加入的技术,它并不是什么划时代的新东西。早在 IE 6 时代,就有一个叫 userData 的东西用于本地存储,而当时考虑到浏览器兼容性,更通用的方案是使用 Flash。而如今,localStorage 被大多数浏览器所支持,如果你的网站需要支持 IE6+,那以 userData 作为你的 polyfill 的方案是种不错的选择。

sessionStorage

sessionStorage 与 localStorage 的接口类似,但保存数据的生命周期与 localStorage 不同。 Session 这个词的意思,直译过来是“会话”。它只是可以将一部分数据在当前会话中保存下来,刷新页面数据依旧存在。但当页面关闭后,sessionStorage 中的数据就会被清空。

cookie、localStorage、sessionStorage异同


接下来就开始上重头戏了 —— indexDB

indexDB

随着浏览器的功能不断增强,越来越多的网站开始考虑,将大量数据储存在客户端,这样可以减少从服务器获取数据,直接从本地获取数据。

通俗地讲,IndexedDB 就是浏览器提供的本地数据库,它可以被网页脚本创建和操作。IndexedDB 允许储存大量数据,提供查找接口,还能建立索引。这些都是 LocalStorage 所不具备的。就数据库类型而言,IndexedDB 不属于关系型数据库(不支持 SQL 查询语句),更接近 NoSQL 数据库。

操作步骤

查看更多信息参考

  • 创建/打开数据库。
  • 在数据库中创建一个对象仓库(object store)。
  • 启动一个事务,并发送一个请求来执行一些数据库操作,像增加或提取数据等。
  • 通过监听正确类型的 DOM 事件以等待操作完成。
  • 在操作结果上进行一些操作(可以在 request 对象中找到)

打开数据库

var db = null;
var request = window.indexedDB.open("MyTestDatabase");
request.onerror = function(event) {// 错误处理console.log(' 打开数据库报错');
};
request.onsuccess = function(event) {// 成功处理db = event.target.result;console.log('打开数据库成功');
};

创建和更新数据库版本号

如果指定的版本号,大于数据库的实际版本号,就会发生数据库升级事件upgradeneeded。这时通过事件对象的target.result属性,拿到数据库实例。

var db = null;
request.onupgradeneeded = function (event) {db = event.target.result;
}

新建数据库

新建数据库与打开数据库是同一个操作。如果指定的数据库不存在,就会新建。不同之处在于,后续的操作主要在upgradeneeded事件的监听函数里面完成,因为这时版本从无到有,所以会触发这个事件。

通常,新建数据库以后,第一件事是新建对象仓库(即新建表)。

request.onupgradeneeded = function(event) {db = event.target.result;var objectStore = null;if (!db.objectStoreNames.contains('imgLists')) {objectStore = db.createObjectStore('imgLists', { keyPath: 'id' });// unique name可能会重复objectStore.createIndex('name', 'name', { unique: false });}
}

创建一张叫imgLists的表格,主键是id。

写入数据

新增数据指的是向对象仓库写入数据记录。这需要通过事务完成。

// new 一个blob对象
var obj1 = {hello: "world"};
var blob = new Blob([JSON.stringify(obj1, null, 2)], {type : 'application/json'});function add() {var request = db.transaction(['imgLists'],  'readwrite').objectStore('imgLists').add({ id: 1, name: '图片1', path: '/static/image', blob:  blob});request.onsuccess = function (event) {console.log('数据写入成功');};request.onerror = function (event) {console.log('数据写入失败');}
}

查询数据

查询数据也是通过事物完成。

function read() {var transaction = db.transaction(['imgLists']);var objectStore = transaction.objectStore('imgLists');// 用户读取数据,参数是主键var request = objectStore.get(1);request.onerror = function(event) {console.log('事务失败');};request.onsuccess = function( event) {if (request.result) {console.log(request.result);} else {console.log('未获得数据记录');}};
}

遍历数据

遍历数据表格的所有记录,要使用指针对象 IDBCursor。

function readAll() {var objectStore = db.transaction('imgLists').objectStore('imgLists');objectStore.openCursor().onsuccess = function (event) {var cursor = event.target.result;if (cursor) {console.log(cursor);cursor.continue();} else {console.log('没有更多数据了!');}};
}

更新数据

function update() {var request = db.transaction(['imgLists'], 'readwrite').objectStore('imgLists')// 主动更新主键为1.put({ id: 1, name: '图片2',  path: '/static/image2'});request.onsuccess = function (event) {console.log('数据更新成功');};request.onerror = function (event) {console.log('数据更新失败');}
}

删除数据

function remove() {var request = db.transaction(['imgLists'], 'readwrite').objectStore('imgLists').delete(1);request.onsuccess = function (event) {console.log('数据删除成功');};
}remove();

创建/使用索引

索引的意义在于,可以让你搜索任意字段,也就是说从任意字段拿到数据记录。如果不建立索引,默认只能搜索主键(即从主键取值)。

    objectStore.createIndex('name', 'name', { unique: false });
    function findIndex() {var transaction = db.transaction(['imgLists'], 'readonly');var store = transaction.objectStore('imgLists');var index = store.index('name');var request = index.get('图片1');request.onsuccess = function (e) {var result = e.target.result;if (result) {console.log(result);} else {// ...}}}

使用场景

indexDB是一个浏览器使用简易的数据库。随着前端功能复杂度提升,用户需要多元化,前端indexDB应用也就越来越多。桌面应用、Progressive Web App(PWA)、chrome扩展组件的开发等。用户同时会获取/操作更多的信息,怎么留存这些大量的数据,那么我们的indexDB就上线了。

转载自:https://www.jianshu.com/p/bb116c7a74b3

前端存储之cookie、localStorage、sessionStorage、indexDB相关推荐

  1. 本地存储-cookie|localStorage|sessionStorage|indexedDB

    本地存储 本地存储 cookie 如何工作 问题 cookie标准限制 属性 expires|max-age domain&path secure HttpOnly 设置cookie 服务端设 ...

  2. cookie localStorage sessionStorage _(¦3」∠)_ 看完你居然就懂了!!!

    知识点 cookie sessionStorage localStorage cookie 本身用于浏览器和server通讯 被 "借用" 到本地存储 可用 document.co ...

  3. 浏览器本地存储(cookie、sessionStorage和localStorage)

    1.Cookie 特点:存储大小4KB左右:可设置失效时间:通信时会携带在HTTP头中,使用cookie保存过多数据会影响性能. 注意:cookie的跨域可以理解为跨域名,只要二级域名相同,不涉及到端 ...

  4. 前端的存储技术cookie、sessionStorage、localStorage

    HTTP无状态协议是指协议对于事务处理没有记忆能力. 会话跟踪 协议的状态是指下一次传输可以"记住"这次传输信息的能力,无状态是指同一个会话(注意什么叫同一个会话) 的连续两个请求 ...

  5. 计算机浏览器存储技术cookie、sessionStorage、localStorage

    HTTP无状态协议是指协议对于事务处理没有记忆能力. 会话跟踪 协议的状态是指下一次传输可以"记住"这次传输信息的能力,无状态是指同一个会话(注意什么叫同一个会话) 的连续两个请求 ...

  6. [JavaScript] Cookie,localStorage,sessionStorage概述

    Cookie Cookie 是一些数据, 存储于你电脑上的文本文件中,当 web 服务器向浏览器发送 web 页面时,在连接关闭后,服务端不会记录用户的信息.Cookie 的作用就是存储 web 页面 ...

  7. js存储数据cookie,localhost,sessionstorage

    存储数据 1.cookie.设置 属性不会被覆盖 特点:内存小只有4kb,可以设置过期时间.而且有些域名会限制 网站里面查找cookie:1.检查 2.Application 3.cookies ​ ...

  8. 存储:Cookie/localStorage

    说到存储,历久弥新,到现在存留下来并被广泛运用的已经所剩无几了,今天我们就来说说Cookie浏览器存储的localStorage本地存储. 注意:查看本地存储需要在服务器环境下,不要忘了开启XAMPP ...

  9. localStorage sessionStorage 和cookie等前端存储方式总结

    localStorage sessionStorage 和cookie localStorage localStorage是本地存储的,除非清空本地数据 localStorage不会自动把数据发给服务 ...

最新文章

  1. 打包无法识别lombok
  2. 推荐 12 个提升程序员软技能与效率的必备工具,爱了爱了!
  3. 专科生,还有未来吗?
  4. SQLiteOpenHelper的简单使用
  5. 活久见啊,WPF工资已经这么高了!
  6. java 8 排序反转_Java 8 排序小结
  7. KnockoutJS-与服务端交互
  8. c语言拔河分组回溯算法,【阅读下面的文字,完成10—12题。文明的共相回溯我们历史演-查字典问答网...
  9. Hadoop系列-HDFS HA高可用集群
  10. 使用python实现栈和队列
  11. 博客开通,以后大家多来玩啊!
  12. 如何突破织梦后台发布文章的250字符的内容摘要字数限制
  13. xmind模板打包下载
  14. GCN使用的数据集Cora、Citeseer、Pubmed、Tox21格式
  15. 【学习笔记】离散数学(Discrete Math) - 证明 Proof 3
  16. PHP编程学习之路 2
  17. 【LeetCode刷题】1619. 删除某些元素后的数组均值
  18. WKWebView加载txt文档乱码
  19. 软件评估报告和软件可行性分析文档搜集
  20. java -Djava.ext.dirs= -jar 启动项目,产生的问题

热门文章

  1. bugku 啊哒 有趣的表情包
  2. 2018(农历年)封山之作,和我一起嚼烂Git(两万字长文)
  3. bootstrap-table+bootstrap+font-awesome+layui+jquery+popper+sweetalert2+layer综合应用+图+代码
  4. 理解区块链的“非对称加密”
  5. 我所看到的印度软件业
  6. 搭建前端错误监控系统
  7. UVa10019:Funny Encryption Method
  8. MATLAB完美画图:改变坐标轴刻度的显示数值,常数函数的作图
  9. 【WZOI】2019愚人节比赛题目分析
  10. 研发人员的几个典型性格特征