IndexedDB是HTML5规范里新出现的浏览器里内置的数据库。对于在浏览器里存储数据,你可使用cookies或local storage,但它们都是比较简单的技术,而IndexedDB提供了相似数据库风格的数据存储和使用方式。存储在IndexedDB里的数据是永久保存,不像cookies那样只是临时的。IndexedDB里提供了查询数据的功能,在online和offline模式下都能使用。你能够用IndexedDB存储大型数据。web
IndexedDB里数据以对象的形式存储,每一个对象都有一个key值索引。IndexedDB里的操做都是事务性的。一种对象存储在一个objectStore里,objectStore就至关于关系数据库里的表。IndexedDB能够有不少objectStore,objectStore里能够有不少对象。每一个对象能够用key值获取。数据库
IndexedDB和LocalStorage都是用来在浏览器里存储数据,但它们使用不一样的技术,有不一样的用途,你须要根据本身的状况适当的选择使用哪一种。LocalStorage是用key-value键值模式存储数据,但跟IndexedDB不同的是,它的数据并非按对象形式存储。它存储的数据都是字符串形式。若是你想让LocalStorage存储对象,你须要借助JSON.stringify()
能将对象变成字符串形式,再用JSON.parse()
将字符串还原成对象。但若是要存储大量的复杂的数据,这并非一种很好的方案。毕竟,localstorage就是专门为小数量数据设计的,它的api是同步的。api
IndexedDB很适合存储大量数据,它的API是异步调用的。IndexedDB使用索引存储数据,各类数据库操做放在事务中执行。IndexedDB甚至还支持简单的数据类型。IndexedDB比localstorage强大得多,但它的API也相对复杂。浏览器
对于简单的数据,你应该继续使用localstorage,但当你但愿存储大量数据时,IndexedDB会明显的更适合,IndexedDB能提供你更为复杂的查询数据的方式。cookie
WebSQL也是一种在浏览器里存储数据的技术,跟IndexedDB不一样的是,IndexedDB更像是一个NoSQL数据库,而WebSQL更像是关系型数据库,使用SQL查询数据。W3C已经再也不支持这种技术。具体状况请看:http://www.w3.org/TR/webdatabase/。网络
由于再也不支持,因此你就不要在项目中使用这种技术了。异步
Cookies(小甜点)听起来很好吃,但实际上并非。每次HTTP接受和发送都会传递Cookies数据,它会占用额外的流量。例如,若是你有一个10KB的Cookies数据,发送10次请求,那么,总计就会有100KB的数据在网络上传输。Cookies只能是字符串。浏览器里存储Cookies的空间有限,不少用户禁止浏览器使用Cookies。因此,Cookies只能用来存储小量的非关键的数据。函数
想要理解IndexedDB,最好的方法是建立一个简单的web应用:把大家班的学生的学号和姓名存储在IndexedDB里。IndexedDB里提供了简单的增、删、改、查接口。spa
首先,你须要知道你的浏览器是否支持IndexedDB。请使用最新版的谷歌浏览器或火狐浏览器。低版本的IE是不行的。设计
window.indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB; if(!window.indexedDB) { console.log("你的浏览器不支持IndexedDB"); }
一旦你的浏览器支持IndexedDB,咱们就能够打开它。你不能直接打开IndexedDB数据库。IndexedDB须要你建立一个请求来打开它。
var request = window.indexedDB.open("testDB", 2);
第一个参数是数据库的名称,第二个参数是数据库的版本号。版本号能够在升级数据库时用来调整数据库结构和数据。
但你增长数据库版本号时,会触发onupgradeneeded
事件,这时可能会出现成功、失败和阻止事件三种状况。
var db; request.onerror = function(event){ console.log("打开DB失败", event); } request.onupgradeneeded = function(event){ console.log("Upgrading"); db = event.target.result; var objectStore = db.createObjectStore("students", { keyPath : "rollNo" }); }; request.onsuccess = function(event){ console.log("成功打开DB"); db = event.target.result; }
onupgradeneeded
事件在第一次打开页面初始化数据库时会被调用,或在当有版本号变化时。因此,你应该在onupgradeneeded
函数里建立你的存储数据。若是没有版本号变化,并且页面以前被打开过,你会得到一个onsuccess
事件。若是有错误发生时则触发onerror
事件。若是你以前没有关闭链接,则会触发onblocked
事件。
在上面的代码片断里,咱们建立了一个Object Store,叫作“students”,用“rollNo”作数据键名。
为了往数据库里新增数据,咱们首先须要建立一个事务,并要求具备读写权限。在indexedDB里任何的存取对象的操做都须要放在事务里执行。
var transaction = db.transaction(["students"],"readwrite"); transaction.oncomplete = function(event) { console.log("Success"); }; transaction.onerror = function(event) { console.log("Error"); }; var objectStore = transaction.objectStore("students"); objectStore.add({rollNo: rollNo, name: name});
删除跟新增同样,须要建立事务,而后调用删除接口,经过key删除对象。
db.transaction(["students"],"readwrite").objectStore("students").delete(rollNo);
我把语句合并到了一块儿,变得更简单,但效果是同样的。
往get()
方法里传入对象的key值,取出相应的对象。
var request = db.transaction(["students"],"readwrite").objectStore("students").get(rollNo); request.onsuccess = function(event){ console.log("Name : "+request.result.name); };
为了更新一个对象,首先要把它取出来,修改,而后再放回去。
var transaction = db.transaction(["students"],"readwrite"); var objectStore = transaction.objectStore("students"); var request = objectStore.get(rollNo); request.onsuccess = function(event){ console.log("Updating : "+request.result.name + " to " + name); request.result.name = name; objectStore.put(request.result); };