indexDB vue 创建数据库 创建表 添加对象数据

1 .open(dbName,1) 版本号可以省略

javascript 复制代码
 let dbName = 'hist-data-1d'
      const request = indexedDB.open(dbName); // 如果你不知道数据库的版本号,可以省略第二个参数,这样 indexedDB 会默认为你打开最新版本的数据库,因为版本号总是自增长的

2 第一次创建表 或数据库版本变化时创建表

javascript 复制代码
// 数据库版本变化时创建表
      request.onupgradeneeded = event => {
        for (let symbol of symbolList) { //  for (let symbol in symbolList) 循环打印出来的是 symbolList 中每个元素的索引
          symbol = symbol.replace('-', '_').toLowerCase();

          const db = event.target.result;
          db.createObjectStore(symbol);
        }
      };

3 指定表 添加数据 key value

javascript 复制代码
 request.onsuccess = event => {

    const db = event.target.result;
    const transaction = db.transaction([tablie], 'readwrite');
    const objectStore = transaction.objectStore(tablie);
    
    let key = 'key'
    const request = objectStore.add(data, key);
}

4 add 是累加数据 put 是只有一条数据

javascript 复制代码
const request = objectStore.add(data, key);

ps

ps1. 如果使用 add 方法添加的数据中 key 已经存在于对象仓库中,则会抛出 ConstraintError 错误

ps2 .需要更新已经存在的数据,你应该使用 put 方法而不是 add 方法

相关推荐
stringwu12 小时前
Flutter GetX 核心坑及架构选型与可替换性方案
前端·flutter
耗子君QAQ12 小时前
为什么 AI 写代码也需要说明书?
前端·javascript·ai编程
h_654321012 小时前
公告/消息提示从右向左循环滚动vue
前端·javascript·vue.js
码农阿豪12 小时前
时序数据库选型指南:我们是怎么评估和选型的
数据库·时序数据库
Lyyaoo.12 小时前
JWT 令牌(待更新)
java·前端·javascript
2301_7965885012 小时前
Go语言如何压缩文件_Go语言gzip压缩教程【基础】
jvm·数据库·python
weixin_4367778712 小时前
el-select的label没有没有反显怎么办?
开发语言·前端·javascript
m0_6178814212 小时前
c++如何通过重定向rdbuf来捕获第三方库的日志输出到文件【详解】
jvm·数据库·python
IntMainJhy12 小时前
【flutter for open harmony】第三方库Flutter 国际化多语言的鸿蒙化适配与实战指南
数据库·flutter·华为·sqlite·harmonyos
米丘12 小时前
vue3.x 编译 script setup 编译过程
vue.js·node.js·babel