千家信息网

HTML5 进阶系列:indexedDB 数据库

发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,前言在 HTML5 的本地存储中,有一种叫 indexedDB 的数据库,该数据库是一种存储在客户端本地的 NoSQL 数据库,它可以存储大量的数据。从上篇:HTML5 进阶系列:web Storag
千家信息网最后更新 2025年11月13日HTML5 进阶系列:indexedDB 数据库

前言

在 HTML5 的本地存储中,有一种叫 indexedDB 的数据库,该数据库是一种存储在客户端本地的 NoSQL 数据库,它可以存储大量的数据。从上篇:HTML5 进阶系列:web Storage ,我们知道 web Storage 可以方便灵活的在本地存取简单数据,但是对于大量结构化存储,indexedDB 的优势就更加明显。接下来我们来看看 indexedDB 如何存储数据。

原文作者:林鑫,作者博客:https://github.com/lin-xin/blog


连接数据库

一个网站可以有多个 indexedDB 数据库,但每个数据库的名称是唯一的。我们需要通过数据库名来连接某个具体的数据库。

var request = indexedDB.open('dbName', 1);  // 打开 dbName 数据库request.onerror = function(e){              // 监听连接数据库失败时执行    console.log('连接数据库失败');}request.onsuccess = function(e){            // 监听连接数据库成功时执行    console.log('连接数据库成功');}

我们使用 indexedDB.open 方法来连接数据库,该方法接收两个参数,第一个是数据库名,第二个是数据库版本号。该方法会返回一个 IDBOpenDBRequest 对象,代表一个请求连接数据库的请求对象。我们可以通过监听请求对象的 onsuccess 和 onerror 事件来定义连接成功或失败需执行的方法。

因为 indexedDB API 中不允许数据库中的数据仓库在同一版本中发生变化,所以需要在 indexedDB.open 方法中传入新的版本号来更新版本,避免在同一版本中重复修改数据库。版本号必须为整数!

var request = indexedDB.open('dbName', 2);  // 更新版本,打开版本为2的数据库// ...request.onupgradeneeded = function(e){    console.log('新数据库版本号为=' + e.newVersion);}

我们通过监听请求对象的 onupgradeneeded 事件来定义数据库版本更新时执行的方法。

关闭数据库

使用 indexedDB.open 连接数据库成功后会返回一个 IDBOpenDBRequest 对象,我们可以调用该对象的 close 方法来关闭数据库。

var request = indexedDB.open('dbName', 2);// ...request.onsuccess = function(e){    console.log('连接数据库成功');    var db = e.target.result;    db.close();    console.log('数据库已关闭');}

删除数据库

indexedDB.deleteDatabase('dbName');console.log('数据库已删除');

创建对象仓库

object store(对象仓库)是 indexedDB 数据库的基础,在indexedDB 中并没有数据库表,而对象仓库,就是相当于一个数据库表。

var request = indexedDB.open('dbName', 3);// ...request.onupgradeneeded = function(e){    var db = e.target.result;    var store = db.createObjectStore('Users', {keyPath: 'userId', autoIncrement: false});    console.log('创建对象仓库成功');}

db.createObjectStore 方法接收两个参数,第一个为对象仓库名,第二个参数为可选参数,值为一个js对象。该对象中的 keyPath 属性为主键,相当于数据库表中 id 为主键。autoIncrement 属性为 false,则表示主键值不自增,添加数据时需指定主键值。

注意:在数据库中,对象仓库名不可重复,否则浏览器会报错。

创建索引

indexedDB 数据库中通过数据对象的某个属性来创建索引,在数据库中进行检索时,只能通过被设为索引的属性进行检索。

var request = indexedDB.open('dbName', 4);// ...request.onupgradeneeded = function(e){    var db = e.target.result;    var store = db.createObjectStore('newUsers', {keyPath: 'userId', autoIncrement: false});    var idx = store.createIndex('usernameIndex','userName',{unique: false})    console.log('创建索引成功');}

store.createIndex 方法接收三个参数,第一个为索引名,第二个为数据对象的属性,上例中使用 userName 属性来创建索引,第三个参数为可选参数,值为一个js对象。该对象中的 unique 属性为 true,代表索引值不可以相同,即两条数据的 userName 不可以相同,为 false 则可以相同。

基于事务

在 indexedDB 中,所有数据操作都只能在事务中执行。连接数据库成功后,可以使用 IDBOpenDBRequest 对象的 transaction 方法开启只读事务或读写事务。

var request = indexedDB.open('dbName', 5);// ...request.onupgradeneeded = function(e){    var db = e.target.result;    var tx = db.transaction('Users','readonly');    tx.oncomplete = function(e){        console.log('事务结束了');    }    tx.onabort = function(e){        console.log('事务被中止了');    }}

db.transaction 方法接收两个参数,第一个参数可以是字符串或数组,字符串时则是一个对象仓库名,数组时则是由对象仓库名组成的数组,transaction 可以对参数中任何一个对象仓库进行操作。第二个参数为事务模式,传入 readonly 时只能对对象仓库进行读操作,无法写操作。可以传入 readwrite 进行读写操作。

操作数据

  • add() : 增加数据。接收一个参数,为需要保存到对象仓库中的对象。

  • put() : 增加或修改数据。接收一个参数,为需要保存到对象仓库中的对象。

  • get() : 获取数据。接收一个参数,为需要获取数据的主键值。

  • delete() : 删除数据。接收一个参数,为需要获取数据的主键值。

var request = indexedDB.open('dbName', 5);// ...request.onsuccess = function(e){    var db = e.target.result;    var tx = db.transaction('Users','readwrite');    var store = tx.objectStore('Users');    var value = {        'userId': 1,        'userName': 'linxin',        'age': 24    }    var req1 = store.put(value);        // 保存数据    var req2 = store.get(1);            // 获取索引userId为1的数据    req2.onsuccess = function(){        console.log(this.result.userName);  // linxin    }    var req3 = store.delete(1);             // 删除索引为1的数据    req3.onsuccess = function(){        console.log('删除数据成功');        // 删除数据成功    }}

add 和 put 的作用类似,区别在于 put 保存数据时,如果该数据的主键在数据库中已经有相同主键的时候,则会修改数据库中对应主键的对象,而使用 add 保存数据,如果该主键已经存在,则保存失败。

检索数据

上面我们知道使用 get() 方法可以获取数据,但是需要制定主键值。如果我们想要获取一个区间的数据,可以使用游标。游标通过对象仓库的 openCursor 方法创建并打开。

openCursor 方法接收两个参数,第一个是 IDBKeyRange 对象,该对象创建方法主要有以下几种:

// boundRange 表示主键值从1到10(包含1和10)的集合。// 如果第三个参数为true,则表示不包含最小键值1,如果第四参数为true,则表示不包含最大键值10,默认都为falsevar boundRange = IDBKeyRange.bound(1, 10, false, false);// onlyRange 表示由一个主键值的集合。only() 参数则为主键值,整数类型。var onlyRange = IDBKeyRange.only(1);// lowerRaneg 表示大于等于1的主键值的集合。// 第二个参数可选,为true则表示不包含最小主键1,false则包含,默认为falsevar lowerRange = IDBKeyRange.lowerBound(1, false);// upperRange 表示小于等于10的主键值的集合。// 第二个参数可选,为true则表示不包含最大主键10,false则包含,默认为falsevar upperRange = IDBKeyRange.upperBound(10, false);

openCursor 方法的第二个参数表示游标的读取方向,主要有以下几种:

  • next : 游标中的数据按主键值升序排列,主键值相等的数据都被读取

  • nextunique : 游标中的数据按主键值升序排列,主键值相等只读取第一条数据

  • prev : 游标中的数据按主键值降序排列,主键值相等的数据都被读取

  • prevunique : 游标中的数据按主键值降序排列,主键值相等只读取第一条数据

var request = indexedDB.open('dbName', 6);// ...request.onsuccess = function(e){    var db = e.target.result;    var tx = db.transaction('Users','readwrite');    var store = tx.objectStore('Users');    var range = IDBKeyRange.bound(1,10);    var req = store.openCursor(range, 'next');    req.onsuccess = function(){        var cursor = this.result;        if(cursor){            console.log(cursor.value.userName);            cursor.continue();        }else{            console.log('检索结束');        }    }}

当存在符合检索条件的数据时,可以通过 update 方法更新该数据:

cursor.updata({    userId : cursor.key,    userName : 'Hello',    age : 18});

可以通过 delete 方法删除该数据:

cursor.delete();

可以通过 continue 方法继续读取下一条数据,否则读到第一条数据之后不再继续读取:

cursor.continue();


数据 数据库 对象 参数 方法 仓库 成功 版本 索引 事务 属性 游标 存储 检索 相同 两个 可以通过 更新 监听 三个 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 5分钟一只神兽的宝可梦服务器 服务器拉漏 广东省网络安全警察总队 服务器布置 江西戴尔服务器虚拟化系统 软件开发计划合理 数据库系统体系结构的最大特点是 进入网络安全应该注意哪些 吉林机电软件开发技术规范 南通满满网络技术有限公司 可信赖的网络安全接入方案 河南常见网络技术的技术开发 labview发送数据到服务器 江苏压铸模具制造管理软件开发 黑魂3怎么登录游戏服务器 牙科X射线影像软件开发 数据库数据怎么调度 河南gisbim软件开发 从生活中了解网络技术 城建大学网络安全与信息化中心 网络安全关乎你我手抄报 三联系三服务器 郑州直播软件开发公司哪家比较好 华为v10网络安全密钥在哪 国家网络安全意识调查报告 六安服务器机箱机柜企业 方舟服务器出租 辽宁电力网络安全 传奇 服务器列表 电视dns服务器不可用什么意思
0