前端数据库 IndexedDB 详解:构建强大的离线Web应用

前端数据库 IndexedDB 详解:构建强大的离线Web应用

引言:为什么需要前端数据库?

在现代Web开发中,我们经常需要处理大量结构化数据。传统的localStoragesessionStorage虽然简单易用,但只能存储少量字符串数据,无法满足复杂应用的需求。IndexedDB应运而生——这是一个功能强大的浏览器内置数据库,支持存储大量结构化数据,提供索引、事务等高级功能,是实现离线应用、缓存机制和复杂数据处理的理想选择。

IndexedDB核心概念解析

1. 数据库(Database)

  • 每个源(协议+域名+端口)可以创建多个数据库
  • 每个数据库包含多个对象存储(类似于SQL中的表)

2. 对象存储(Object Store)

  • 存储键值对集合的主要容器
  • 键可以是路径、自增数字或自定义键生成器
  • 值可以是任何结构化可克隆对象

3. 索引(Index)

  • 允许高效查询对象存储中的数据
  • 可以基于对象属性创建多个索引
  • 支持唯一索引约束

4. 事务(Transaction)

  • 所有操作都在事务中执行
  • 三种模式:只读(readonly)、读写(readwrite)和版本变更(versionchange)
  • 提供原子性保证(全部成功或全部失败)

5. 游标(Cursor)

  • 用于遍历对象存储或索引中的记录
  • 支持方向控制(前进/后退)和范围查询

完整代码示例:实现一个联系人管理器

1. 初始化数据库

// 打开或创建数据库const dbName ='ContactDB';const dbVersion =1;const request = indexedDB.open(dbName, dbVersion); request.onerror=(event)=>{  console.error('数据库打开失败:', event.target.error);}; request.onupgradeneeded=(event)=>{ const db = event.target.result;// 创建对象存储(如果不存在)if(!db.objectStoreNames.contains('contacts')){ const store = db.createObjectStore('contacts',{  keyPath:'id', autoIncrement:true});// 创建索引 store.createIndex('name','name',{  unique:false}); store.createIndex('email','email',{  unique:true}); store.createIndex('phone','phone',{  unique:false}); store.createIndex('group','group',{  unique:false});}}; request.onsuccess=(event)=>{ const db = event.target.result; console.log('数据库成功打开');// 存储数据库引用供后续使用 window.contactDB = db;};

2. 添加联系人

functionaddContact(contact){ returnnew

Read more

【Matlab】最新版2025a发布,深色模式、Copilot编程助手上线!

【Matlab】最新版2025a发布,深色模式、Copilot编程助手上线!

文章目录 * 一、软件安装 * 1.1 系统配置要求 * 1.2 安装 * 二、新版功能探索 * 2.1 界面图标和深色主题 * 2.2 MATLAB Copilot AI助手 * 2.3 绘图区升级 * 2.4 simulink * 2.5 更多 🟠现在可能无法登录或者注册mathworks(写这句话的时间:2025-05-20): 最近当你登录或者注册账号的时候会显示:no healthy upstream,很多人都遇到了这个问题,我在reddit上看到了mathworks官方的回答:确实有这个问题,正在恢复,不知道要几天咯,大家先用旧版本吧。 — 已经近10天了,原因是:遭受勒索软件攻击 延迟一个月,终于发布了🤭。 一、软件安装 1.1

StructBERT-Large实战教程:单句对多句批量检索模式扩展开发指南

StructBERT-Large实战教程:单句对多句批量检索模式扩展开发指南 1. 项目概述与核心价值 如果你正在处理中文文本的语义匹配任务,比如从大量文档中快速找到相关内容,或者需要判断两个句子的相似程度,那么StructBERT-Large将是你的得力助手。 这个工具基于阿里达摩院开源的StructBERT大规模预训练模型,专门针对中文语义理解进行了优化。与传统的文本匹配方法不同,它能够深入理解句子的语法结构和语义内涵,将中文句子转化为高质量的数值向量(Embedding),然后通过数学计算精确量化两个句子之间的相似程度。 核心能力亮点: * 深度理解中文语法和语义结构 * 将文本转换为可计算的数值向量 * 快速准确计算句子相似度 * 支持扩展到批量文本处理场景 2. 环境准备与快速部署 2.1 系统要求与依赖安装 在开始之前,确保你的系统满足以下要求: * Python 3.8或更高版本 * NVIDIA显卡(推荐RTX 4090或同级别显卡) * 至少8GB系统内存 * 足够的显卡显存(模型加载需要约1.5-2GB) 安装必要的依赖库:

【如何使用vscode+github copilot会更加省额度】

【如何使用vscode+github copilot会更加省额度】

这是一份为您定制的 VS Code + GitHub Copilot ($100/年个人版) 深度使用与省流指南。 如果您目前订阅的是 100美元/年(约10美元/月)的 GitHub Copilot Individual (现通常称为 Pro 版),虽然基础代码补全通常是无限制的,但在使用高级大模型(Premium Models,如 Claude 3.5/4.5 Sonnet, GPT-4o 等)进行对话 (Chat) 时,是存在“高级请求额度 (Premium Requests Limit)”或动态计算系统的。一旦超标,要么会被限速,要么只能降级使用基础模型。 以下是详细的收费标准说明与极端的“省流”实操指南。 📘 GitHub Copilot