HTML5中封装Promise风格的数据库初始化工具函数

openDB 是一个返回 Promise 的 IndexedDB 初始化工具函数,接收数据库名、版本号和升级回调,自动处理版本升级、错误捕获与连接复用。在 HTML5 中使用 IndexedDB 时,原生 API 是事件驱动、回调嵌套的,写起来繁琐且难以维护。封装一个 Promise 风格的数据库初始化工具函数,能显著提升可读性与复用性。核心目标:返回 Promise 的 openDB 工具函数该函数应接收数据库名、版本号和可选的升级逻辑,返回一个解析为 IDBDatabase 实例的 Promise。失败时 reject 错误,成功时 resolve 数据库对象,并确保只在必要时执行 upgrade 逻辑。自动处理版本变更(仅当请求版本 > 当前版本时触发 onupgradeneeded) 统一错误捕获(onerror 和 onblocked 可选处理) 避免重复打开(内部缓存已打开的连接,相同 name + version 复用)基础实现(兼容现代浏览器)以下是一个轻量、无依赖的封装示例:function openDB(name, version = 1, upgradeCb = null) { return new Promise((resolve, reject) => { const request = indexedDB.open(name, version); request.onerror = () => reject(request.error); request.onsuccess = () => resolve(request.result); request.onupgradeneeded = (event) => { const db = event.target.result; if (typeof upgradeCb === 'function') { upgradeCb(db, event.oldVersion, event.newVersion, event.transaction); } }; // 可选:处理数据库被其他标签页占用的情况 request.onblocked = () => reject(new Error('Database is blocked --- close other tabs using it')); });}调用方式简洁直观: 知网AI智能写作 知网AI智能写作,写文档、写报告如此简单

相关推荐
●VON19 小时前
鸿蒙Flutter实战:分类管理页BottomSheet CRUD
数据库·flutter·华为·harmonyos·鸿蒙
Cosolar19 小时前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
风吹夏回20 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
小熊Coding20 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
企服AI产品测评局20 小时前
Agent适配信创环境实测:企业级自动化如何实现国产操作系统与数据库全兼容?
运维·数据库·人工智能·ai·chatgpt·自动化
秋920 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本20 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
cfm_291420 小时前
Redis数据安全性解析
数据库·redis·缓存
DIY源码阁21 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
田里的水稻21 小时前
OE_ubuntu26.04与宿主机之间复制粘贴内容
人工智能·python·机器人