使用Dexie操作前端数据库IndexedDB 教程

使用Dexie操作前端数据库IndexedDB 教程

Dexie.js 是对前端本地数据库 IndexedDB 的 API 进行封装的轻量级库,它简化了 IndexedDB 复杂的原生操作,提供了更简洁、直观的语法,便于开发者快速实现前端本地数据的持久化存储。

一、为什么选择 IndexedDB?

前端常见的本地存储方案(Cookie、LocalStorage、SessionStorage)均存在存储容量限制,无法满足大数据量的存储需求。IndexedDB 作为浏览器原生的本地数据库,具备大容量存储优势,具体对比如下:

  • Cookie:存储容量不超过 4KB,主要用于存储会话标识等少量信息;
  • LocalStorage:存储容量介于 2.5MB ~ 10MB 之间,仅支持字符串存储;
  • SessionStorage:存储容量与 LocalStorage 相当,但仅在当前会话有效,页面关闭后数据丢失;
  • IndexedDB:存储容量不低于 250MB,支持占用本地磁盘空间的 50%,可存储大量结构化数据,支持事务、索引等数据库核心特性。

二、安装 Dexie

使用包管理器(pnpm、npm、yarn)快速安装 Dexie:

pnpmadd dexie 

三、核心操作步骤

3.1 创建数据库(Database)

通过 new Dexie() 创建数据库实例,指定数据库名称。若数据库不存在则自动创建,若已存在则直接打开。

3.2 创建表(Table)

通过 version().stores() 定义数据库版本及表结构,包括主键、索引等信息。表结构定义需与数据库版本绑定,版本升级时可同步更新表结构。

importtype{ Table }from'dexie';// 定义表结构:版本1中创建 "users" 表 db.version(1).stores({ users:'++id, userName',// ++id 表示自增长主键;userName 表示为该字段创建索引});// 获取 "users" 表实例,用于后续数据操作let users: Table<StoreUserData>; users = db.table('users');

说明:

  • ++id:自增长整数主键,插入数据时无需手动指定 id,数据库会自动生成;
  • userName:为该字段创建索引,可提升按 userName 查询的效率。

3.3 数据操作:增删改查(CRUD)

3.3.1 新增数据(增)

使用 add() 方法插入单条数据,主键(id)会自动生成。

// 插入一条用户数据,无需指定 id db.users.add({ userName:'zhangsan'});
3.3.2 修改/新增数据(改)

使用 put() 方法实现“插入或更新”(upsert)功能:若数据不存在(根据主键判断)则新增,若已存在则覆盖修改。

// 若 id=1 的数据存在则修改 userName,不存在则新增该数据 db.users.put({ id:1, userName:'zhangsan'});

3.3.3 删除数据(删)

使用 delete() 方法根据主键删除单条数据。

3.3.4 查询数据(查)

Dexie 提供了丰富的查询方法,支持按主键查询、条件查询、排序、分页等场景:

// 1. 按主键查询单条数据 db.users.get(1).then(res =>console.log('主键id=1的用户:', res));// 2. 条件查询(两种常用方式)// 方式1:按字段条件查询 db.users.where('userName').equals('zhangsan').toArray().then(res =>console.log('用户名为zhangsan的用户:', res));// 方式2:按对象匹配条件查询 db.users.where({ userName:'zhangsan'}).toArray().then(res =>console.log('用户名为zhangsan的用户:', res));// 3. 查询第一条数据(按id升序) db.users.orderBy('id').first().then(res =>console.log('第一条用户数据:', res));// 4. 查询最后一条数据(按id升序) db.users.orderBy('id').last().then(res =>console.log('最后一条用户数据:', res));// 5. 查询表中数据总数 db.users.count().then(count =>console.log('用户总数:', count));// 6. 分页查询(按id倒序,查询前100条数据) db.users.orderBy('id').reverse()// 倒序排列(默认升序).offset(0)// 偏移量,从第0条开始(即跳过前0条).limit(100)// 限制查询数量,最多返回100条.toArray().then(res =>console.log('分页查询结果:', res));

四、TypeScript 封装优化

通过类封装数据库操作,结合 TypeScript 类型定义,提升代码可维护性和类型安全性:

importtype{ Table }from'dexie';import Dexie from'dexie';// 定义用户数据类型接口,约束数据结构exportinterfaceStoreUserData{ id?:number;// 主键可选,插入时自动生成 userName:string;// 用户名,必传字段}// 封装数据库类exportclassUserDataBaseextendsDexie{// 定义表实例,指定数据类型 users!: Table<StoreUserData>;// 数据库版本private localVersions =1;constructor(){// 调用父类构造函数,指定数据库名称super('UserDataBase');// 初始化数据库版本和表结构this.version(this.localVersions).stores({ users:'++id, userName'// 与前文表结构一致});// 赋值表实例this.users =this.table('users');}}// 创建数据库实例,供全局使用exportconst usersDB =newUserDataBase();

五、查看 IndexedDB 数据

可通过浏览器开发者工具直观查看和操作 IndexedDB 中的数据,步骤如下:

  1. 打开浏览器(Chrome/Firefox/Edge 等)的开发者工具(快捷键 F12 或 Ctrl+Shift+I);
  2. 切换到「应用」(Application)面板;
  3. 在左侧导航栏中找到「存储」-「IndexedDB」;
  4. 展开对应数据库(如 UserDataBase)和表(如 users),即可查看表中数据,支持新增、修改、删除等操作。

六、参考资料

Read more

Bodymovin终极指南:从AE动画到Web部署的完整解决方案

Bodymovin终极指南:从AE动画到Web部署的完整解决方案 【免费下载链接】bodymovin-extensionBodymovin UI extension panel 项目地址: https://gitcode.com/gh_mirrors/bod/bodymovin-extension 在当今数字体验时代,After Effects动画的Web化部署已成为前端开发的必备技能。Bodymovin插件通过其强大的数据转换引擎和渲染优化技术,彻底解决了AE动画在Web环境中的兼容性和性能瓶颈问题。本文将深度解密Bodymovin的核心技术实现,并提供从环境搭建到生产部署的完整操作指南。 核心技术解密:数据转换与渲染优化 Bodymovin的核心竞争力在于其精密的数据解析引擎和格式转换系统。位于bundle/jsx/utils/目录下的核心模块构成了整个系统的数据处理基础。 动画数据解析机制深度剖析 ProjectParser.jsx模块采用分层解析策略,首先识别AE项目中的图层层级结构,然后逐层提取动画属性数据。该模块通过智能算法自动过滤不支持的特效和属性,确保输出

Kylin(麒麟)V10系统安装WebLogic 12C

Kylin(麒麟)V10系统安装WebLogic 12C

目录 前言 一、JDK环境 二、安装WebLogic 1. 下载安装包 2. 开始安装 前言 先说下服务器的情况:我的环境是国产化环境,所以和之前的X86架构有些区别之处。 CPU是华为鲲鹏(Kunpeng)ARM64(aarch64)指令集架构,所以操作系统是:Kylin Linux Advanced Server V10 (ARM64) 。 由此我们在安装其他软件的时候也要注意这一点了,需要下载安装ARM64(aarch64)指令集架构的软件了,不然会会报指令集不符的相关错误提示。 一、JDK环境 Kylin V10系统默认安装匹配的是OpenJDK。 这里我安装WebLogic 12C时使用的是Oracle JDK。当然OpenJDK应该也是可以的。 JDK要求:WebLogic 12.2.1.4 需要 JDK 8(1.8.

YOLO12目标检测WebUI:5分钟快速部署实战教程

YOLO12目标检测WebUI:5分钟快速部署实战教程 1. 引言:为什么选择YOLO12? 你有没有想过,让计算机像人眼一样快速识别图片中的物体?从自动驾驶汽车识别行人,到工厂流水线检测产品缺陷,目标检测技术正在改变我们的生活。而在众多检测模型中,YOLO系列一直以其"又快又准"的特点备受青睐。 YOLO12作为该系列的最新成员,在2025年初由纽约州立大学布法罗分校与中国科学院大学团队联合发布。这个以注意力机制为核心的实时目标检测模型,在保持YOLO系列高速推理优势的同时,进一步提升了检测精度。 今天,我将带你用短短5分钟时间,快速部署一个基于YOLO12的WebUI目标检测服务。无需深厚的AI背景,只要跟着步骤操作,你就能拥有一个功能完整的物体识别系统! 2. 环境准备与快速部署 2.1 系统要求 在开始之前,请确保你的系统满足以下基本要求: * 操作系统:Ubuntu 18.04+ 或 CentOS 7+ * 内存:至少4GB RAM(推荐8GB) * 存储空间:10GB可用空间 * Python版本:3.8或更高版本

Vue-Vben-Admin 从入门到实战:后端开发的前端探索之旅

Vue-Vben-Admin 从入门到实战:后端开发的前端探索之旅

技术视野拓展,从后端视角开启前端探索之旅 1. 概述:一名后端工程师的前端初体验 作为一名深耕后端多年的Java工程师,一直围绕着Spring全家桶、微服务、中间件和分布式架构等后端技术栈。前端世界对我而言,虽说感觉并不陌生,但总是带着一层神秘面纱,知识点零散,理解停留在表面。 直到某天,我在GitHub上偶然发现了Vue-Vben-Admin——这个拥有超过30k⭐️的热门前端脚手架,瞬间吸引了我的注意。它基于Vue3、TypeScript和Vite等前沿技术栈,提供了一套能够快速搭建企业级管理后台的前端解决方案。 为什么Vue-Vben-Admin如此火爆? 🔥 技术栈前沿 - 采用Vue3+TypeScript+Vite,这些都是当前前端生态中最新、最热门的技术组合 🔥 开箱即用 - 内置企业级项目所需的各种功能:权限管理、多种布局、主题切换、丰富示例,应有尽有 🔥 代码规范 - 严格的代码规范和类型检查,让后端开发者也能写出高质量的前端代码 🔥 性能优异 - 基于Vite的快速冷启动和热更新,开发体验流畅 🔥 多UI库支持 - 支持Ant Desi