IndexedDB是HTML5的浏览器端NoSQL数据库,用于存储大量结构化数据。通过open创建或打开数据库,在onupgradeneeded中定义对象仓库和索引;使用readwrite事务添加、更新、删除数据,readonly事务读取或遍历数据;支持主键操作与索引查询,适合离线应用持久化存储,实际开发可结合localForage等库简化API操作。

IndexedDB 是 HTML5 提供的一个浏览器端的 NoSQL 数据库,适合存储大量结构化数据,比如文件、图片的元信息,或者离线应用中的用户数据。它支持事务操作、索引查询,能在客户端持久化保存数据,不依赖网络。下面介绍它的基本使用方法和实际操作示例。
使用 IndexedDB 第一步是打开或创建一个数据库。如果数据库不存在,会自动创建。
<strong>let db;</strong>
const request = indexedDB.open("MyDatabase", 1); // 数据库名和版本号
request.onerror = function(event) {
console.log("数据库打开失败");
};
request.onsuccess = function(event) {
db = event.target.result;
console.log("数据库打开成功");
};
// 只在数据库首次创建或版本更新时触发
request.onupgradeneeded = function(event) {
db = event.target.result;
// 创建一个对象仓库(类似表)
if (!db.objectStoreNames.contains("users")) {
const objectStore = db.createObjectStore("users", { keyPath: "id", autoIncrement: true });
// 添加索引便于查询
objectStore.createIndex("email", "email", { unique: true });
objectStore.createIndex("name", "name", { unique: false });
}
};
说明: onupgradeneeded 是定义数据结构的关键时机,只能在这里创建或删除对象仓库和索引。keyPath 指定主键字段,autoIncrement 表示主键自增。
通过事务向对象仓库中插入数据。
立即学习“前端免费学习笔记(深入)”;
动态WEB网站中的PHP和MySQL详细反映实际程序的需求,仔细地探讨外部数据的验证(例如信用卡卡号的格式)、用户登录以及如何使用模板建立网页的标准外观。动态WEB网站中的PHP和MySQL的内容不仅仅是这些。书中还提到如何串联JavaScript与PHP让用户操作时更快、更方便。还有正确处理用户输入错误的方法,让网站看起来更专业。另外还引入大量来自PEAR外挂函数库的强大功能,对常用的、强大的包
508
function addUser(name, email) {
const transaction = db.transaction(["users"], "readwrite");
const store = transaction.objectStore("users");
const user = { name, email };
const request = store.add(user);
request.onsuccess = function() {
console.log("用户添加成功,ID:", request.result);
};
request.onerror = function() {
console.log("添加失败,可能是邮箱重复");
};
}
// 使用示例
addUser("张三", "zhangsan@example.com");
注意: 必须开启 readwrite 事务才能写入数据。若字段设置了 unique: true(如 email),重复值会触发错误。
支持按主键读取、按索引查询、遍历所有记录等操作。
function getUserById(id) {
const transaction = db.transaction(["users"], "readonly");
const store = transaction.objectStore("users");
const request = store.get(id);
request.onsuccess = function() {
if (request.result) {
console.log("找到用户:", request.result);
} else {
console.log("未找到该用户");
}
};
}
function getUserByEmail(email) {
const transaction = db.transaction(["users"], "readonly");
const store = transaction.objectStore("users");
const index = store.index("email");
const request = index.get(email);
request.onsuccess = function() {
if (request.result) {
console.log("通过邮箱找到用户:", request.result);
}
};
}
function listAllUsers() {
const transaction = db.transaction(["users"], "readonly");
const store = transaction.objectStore("users");
store.openCursor().onsuccess = function(event) {
const cursor = event.target.result;
if (cursor) {
console.log("用户:", cursor.value);
cursor.continue(); // 继续下一条
} else {
console.log("遍历完成");
}
};
}
修改或移除已有记录也很简单。
function updateUser(id, newName) {
const transaction = db.transaction(["users"], "readwrite");
const store = transaction.objectStore("users");
const request = store.get(id);
request.onsuccess = function() {
const user = request.result;
if (user) {
user.name = newName;
const updateRequest = store.put(user);
updateRequest.onsuccess = () => console.log("更新成功");
}
};
}
function deleteUser(id) {
const transaction = db.transaction(["users"], "readwrite");
const store = transaction.objectStore("users");
const request = store.delete(id);
request.onsuccess = function() {
console.log("删除成功");
};
}
基本上就这些。掌握 open、add、get、put、delete 和游标遍历,就能应对大多数前端本地存储需求。IndexedDB 功能强大但 API 较底层,实际项目中可结合封装库如 localForage 简化操作。关键是理解事务机制和异步流程控制。
以上就是HTML5IndexedDB怎么使用_HTML5IndexedDB数据库的操作方法与实例的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号