【汇总】解决IndexedDB报Failed to execute ‘transaction‘ on ‘IDBDatabase‘

问题发现

再学习HTML5中,有介绍到 Web 存储,当代码编写完成后,运行报错

Failed to execute ‘transaction’ on ‘IDBDatabase’: One of the specified object stores was not found.

示例代码如下:

<!DOCTYPE html>
<html>
<head><title>网页标题</title>
</head>
<body><button onclick="addData()">添加数据</button><button onclick="getData()">获取数据</button><script>// 打开或创建数据库const request = window.indexedDB.open('myDatabase', 1);request.onupgradeneeded = function(event) {const db = event.target.result;// 创建一个对象存储空间const objectStore = db.createObjectStore('myObjectStore', { keyPath: 'id' });// 创建索引,可提高检索性能objectStore.createIndex('name', 'name', { unique: false });};request.onsuccess = function(event) {const db = event.target.result;function addData() {// 开启事务const transaction = db.transaction(['myObjectStore'], 'readwrite');const objectStore = transaction.objectStore('myObjectStore');const data = { id: 1, name: 'John Doe', age: 30 };// 添加数据const request = objectStore.add(data);request.onsuccess = function() {console.log('数据添加成功');};transaction.oncomplete = function() {console.log('事务完成');};transaction.onerror = function(event) {console.log('事务错误:', event.target.error);};}function getData() {// 开启只读事务const transaction = db.transaction(['myObjectStore'], 'readonly');const objectStore = transaction.objectStore('myObjectStore');// 检索数据const request = objectStore.get(1);request.onsuccess = function(event) {const data = event.target.result;if (data) {console.log('检索到的数据:', data);} else {console.log('未找到该数据');}};transaction.oncomplete = function() {console.log('事务完成');};transaction.onerror = function(event) {console.log('事务错误:', event.target.error);};}window.addData = addData;window.getData = getData;};request.onerror = function(event) {console.log('打开数据库失败:', event.target.error);};</script>
</body>
</html>

问题解决

先确认对象存储空间是否已经创建,名称是否正确。

方法一:添加版本号

const request = window.indexedDB.open('myDatabase', 1);

如果版本设置为1不行,就设置为其他版本号(这是网上给出的解决方案,貌似没什么用)。

方法二:更换浏览器

默认情况下使用Chrome浏览器,然后报此问题,更换为IE浏览器或其他浏览器,问题解决。

在这里插入图片描述

方法三:使用服务器运行

VS Code中使用Live Server插件运行html,或者使用Tomcat

在这里插入图片描述

问题解决。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/684745.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1Coze平台介绍

2023年随着OpenAI推出GPT 3.5&#xff0c;AI赛道变得更加火热。GPT&#xff08;Generative Pre-trained Transformer&#xff09;是一种自然语言处理&#xff08;NLP&#xff09;模型&#xff0c;用于生成文本、理解语言和进行各种语言任务。GPT是由OpenAI开发的&#xff0c;它…

Tuxera NTFS2024版本的文件操作功能有哪些特点?

Tuxera NTFS通过集成先进的文件系统驱动程序和算法&#xff0c;实现了对多种文件系统的全面支持。具体来说&#xff0c;它具备以下功能和特点&#xff0c;使其能够支持多种文件系统&#xff1a; Tuxera NTFS2024下载如下: https://wm.makeding.com/iclk/?zoneid58824 先进的…

shumei 滑块 qd参数仿写记录

在对qd参数进行仿写的过程中&#xff0c;由于缺失很多js的基础知识&#xff0c;导致进展一度非常的缓慢&#xff0c;并且不知道自己的方向是不是正确的方向。在不知道自己的方向是否正确的时候&#xff0c;这个时候自己的投入的努力都是畏首畏尾。大概是一种&#xff0c;不知道…

实验5-6 使用函数判断完全平方数

本题要求实现一个判断整数是否为完全平方数的简单函数。 函数接口定义&#xff1a; int IsSquare( int n ); 其中n是用户传入的参数&#xff0c;在长整型范围内。如果n是完全平方数&#xff0c;则函数IsSquare必须返回1&#xff0c;否则返回0。 裁判测试程序样例&#xff1…

Python 播放音乐

本篇是使用Python pygame库来实现操作音乐。 安装pygame 播放音乐需要pygame库&#xff0c;如果没有可以进行安装。 命令如下&#xff1a; pip install pygame 引入类库 需要引入两个类库&#xff0c;即time和pygame。 示例如下&#xff1a; import time import pygame 播…

基于剪贴板的文件传输方案

文章目录 背景原理步骤获取待上传文件的十六进制数据格式转换输出 背景 某次误删了环境上的C库之后想到的 什么都不可用了&#xff0c;但当前的ssh连接还在&#xff0c;echo命令和重定向符还可以使用 这就催生了我的想法&#xff1a;直接用echo -en “\xab\xcd” > file这样…

20240215-查找周长最大的多边形

题目要求 给你一个由长度为 n 的正整数 nums 组成的数组。 多边形是至少有 3 条边的封闭平面图形。多边形的最长边小于其他边之和。 相反&#xff0c;如果有 k 个&#xff08;k > 3&#xff09;正实数 a1、a2、a3、...、ak&#xff0c;其中 a1 < a2 < a3 < ... …

【c++】析构函数

1.特征 析构函数是特殊的成员函数&#xff0c;其特征如下&#xff1a; 1.析构函数名是在类名前加上字符~。 2.无参数无返回值类型。 3.一个类只能有一个析构函数。若未显式定义&#xff0c;系统会自动生成默认的析构函数。注意&#xff1a;析构函数不能重载。 4.对象生命周…

StringBuffer线程安全而StringBuilder线程不安全

下面我们从append方法的源码进行分析 StringBuilder Overridepublic StringBuilder append(String str) {super.append(str);return this;} StringBuffer Overridepublic synchronized StringBuffer append(String str) {toStringCache null;super.append(str);return this…

H12-821_48

48.下面是台路由器输出的BGP信息,关于这段信息描述措误的是 A.路由器的Router ID是1.1.1.9 B.display bgp network命令来显示BGP通过network ( BGP)的通告的路由信息 C.该路由器所在AS号是10 D.该路由器通过import-route命今引入了4.4.4.0/24的网段 答案&#xff1a;D 注释&am…

假期作业 10

1.整理磁盘操作的完整流程&#xff0c;如何接入虚拟机&#xff0c;是否成功识别&#xff0c;对磁盘分区工具的使用&#xff0c;格式化&#xff0c;挂载以及取消挂载 U盘接入虚拟机 在虚拟机--->可移动设备--->找到U盘---->连接 检测U盘是否被虚拟机识别 ls /dev/s…

Diffusion Transformer U-Net for MedicalImage Segmentation

用于医学图像分割的扩散变压器U-Net 摘要&#xff1a; 扩散模型在各种发电任务中显示出其强大的功能。在将扩散模型应用于医学图像分割时&#xff0c;存在一些需要克服的障碍:扩散过程调节所需的语义特征与噪声嵌入没有很好地对齐;这些扩散模型中使用的U-Net骨干网对上下文信…

Codeforces Round 926 (Div. 2)(A~C)

A. Sasha and the Beautiful Array 分析&#xff1a;说实话&#xff0c;打比赛的时候看到这题没多想&#xff0c;过了一下样例发现将数组排序一下就行&#xff0c;交了就过了。刚刚写题解反应过来&#xff0c;a2-a1a3-a2.....an-a(n-1) an - a1&#xff0c;所以最后结果只取决…

103.二叉树的锯齿形层序遍历

​​题目来源&#xff1a; leetcode题目&#xff0c;网址&#xff1a;103. 二叉树的锯齿形层序遍历 - 力扣&#xff08;LeetCode&#xff09; 解题思路&#xff1a; 每一层从左到右遍历&#xff0c;逐一判断是否需要反转。 解题代码&#xff1a; /*** Definition for a bina…

Python字典全面指南:基础操作与高级应用实例解析

在Python编程中&#xff0c;字典作为核心的数据结构之一&#xff0c;凭借其高效查询、动态添加与删除属性&#xff0c;成为了处理键值对数据的理想选择。本文将逐步详解Python字典的基本操作&#xff0c;并通过实际案例展示如何查找共同键、设置默认值、更新字典、合并字典&…

python工具方法 45 基于ffmpeg以面向对象多线程的方式实现实时推流

1、视频推流 参考基于ffmpeg模拟监控摄像头输出rtsp视频流并opencv播放 实现视频流的推流。 其基本操作就是,安装视频流推流服务器,ffmpeg,准备好要推流的视频。 命令如下所示:ffmpeg -re -stream_loop -1 -i 风景视频素材分享.flv -c copy -f rtsp rtsp://127.0.0.1:554/…

Java数组,你想要的重点都在这。

1.数组的概述 数组 , 就可以理解为多个多个数据的组合 是程序中的容器 : 数组 , 集合框架(以后会将 : List , Set , Map) 数组存储中的数据的特点 : 依次紧密排列 , 有序的 , 可以重复的 此时的数组 , 集合框架都是在内存中对多个数据的存储 . 数组的其他特点 : 一旦初始化…

STM32 与 ARM 谁比较强大?

STM32 和 ARM 是两个不同的概念&#xff0c;STM32 是一种微控制器产品&#xff0c;而 ARM 是一家处理器架构设计和许可的公司。因此&#xff0c;无法简单地比较它们的强大程度。 STM32 是基于 ARM Cortex-M 核的微控制器产品&#xff0c;具有高性能、低功耗、低成本和易于开发等…

突破编程_C++_高级教程(多线程编程的基础知识)

1 多线程编程基础 线程是操作系统能够进行运算调度的最小单位&#xff0c;它被包含在进程之中&#xff0c;每个进程至少有一个线程&#xff0c;即主线程。线程依赖于进程&#xff0c;不能单独存在。线程的主要作用是实现并发执行&#xff0c;即多个线程可以同时执行不同的任务…

怎么搭建自己的网站?

怎么搭建自己的网站 一.领取一个免费域名和SSL证书&#xff0c;和CDN 特点&#xff1a;支持Cloudflare CDN Cloudflare是全球知名的CDN提供商&#xff0c;如果你不想暴露你的源站&#xff0c;又想使用我们的二级域名&#xff0c;不需要前往Cloudflare添加域名&#xff0c;修…