返回顶部
首页 > 资讯 > 数据库 >怎么使用IndexedDB
  • 955
分享到

怎么使用IndexedDB

2024-04-02 19:04:59 955人浏览 薄情痞子
摘要

这篇文章主要讲解了“怎么使用IndexedDB”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用IndexedDB”吧!深入研究IndexedDB AP

这篇文章主要讲解了“怎么使用IndexedDB”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用IndexedDB”吧!

深入研究IndexedDB API及其在实践中的用法。

你是否听说过浏览器上的NoSQL数据库?

IndexedDB是大型Nosql存储系统。它使你几乎可以将任何内容存储在用户的浏览器中。除了通常的搜索,获取和放置操作外,IndexedDB还支持事务

你可以在下面找到IndexedDB的示例。

怎么使用IndexedDB

在本文中,我们将重点介绍以下内容。

  • 为什么我们需要IndexedDB?

  • 我们如何在我们的应用程序中使用IndexedDB?

  • IndexedDB的功能

  • IndexedDB的局限性

  • IndexedDB是否适合你的应用程序?

为什么我们需要IndexedDB?

IndexedDB被认为比localStorage更强大!

你知道背后的原因吗?让我们找出答案。

可以存储比localStorage大得多的数据量

没有像 localStorage  这样的特殊限制(介于2.5MB和10MB之间)。最大限制取决于浏览器和磁盘空间。例如,基于Chrome和Chromium的浏览器最多允许80%的磁盘空间。如果你有100GB,则IndexedDB最多可以使用80GB的空间,单个origin最多可以使用60GB。Firefox允许每个origin最多2GB,而Safari允许每个来源最多1GB。

可以存储基于{ key: value }对的任何类型的值

存储不同数据类型的灵活性更高。这不仅意味着字符串,而且还意味着二进制数据(ArrayBuffer对象,Blob对象等)。它使用对象存储在内部保存数据。

提供查找界面

这在其他浏览器存储选项(例如 localStorage 和 sessionStorage)中不可用。

对于不需要持续互联网连接的WEB应用程序很有用

IndexedDB对于联机和脱机工作的应用程序都非常有用,例如,它可以用于渐进式Web应用程序(PWA)中的客户端存储。

应用状态可以存储

通过为经常使用的用户存储应用程序状态,可以大大提高应用程序的性能。稍后,应用程序可以与后端服务器同步,并通过延迟加载来更新应用程序。

我们来看看IndexedDB的结构,它可以存储多个数据库

IndexedDB的结构

怎么使用IndexedDB

我们如何在我们的应用程序中使用IndexedDB?

在以下部分中,我们将研究如何使用IndexedDB引导应用程序。

1. 使用“window.indexedDB”打开数据库连接

const openingRequest = indexedDB.open('UserDB', 1);

在这里 UserDB 是数据库名称,1 是数据库的版本。这将返回一个对象,该对象是 IDBOpenDBRequest 接口的实例。

2. 创建对象存储

打开数据库连接后,将触发 onupgradeneeded 事件,可用于创建对象存储。

// 创建UserDetails对象存储库和索引 request.onupgradeneeded = (event) => {   let db = event.target.result;    // 创建UserDetails对象存储   // 具有自动递增ID   let store = db.createObjectStore('UserDetails', {     autoIncrement: true   });    // 在NIC属性上创建索引   let index = store.createIndex('nic', 'nic', {     unique: true   }); };

3. 将数据插入对象存储

一旦打开了与数据库的连接,就可以在 onsuccess 事件处理程序中管理数据。插入数据发生在4个步骤中。

function insertUser(db, user) {   // 创建一个新事物   const txn = db.transaction('User', 'readwrite');    // 获取UserDetails对象存储   const store = txn.objectStore('UserDetails');   // 插入新记录   let query = store.put(user);    // 处理成功用例   query.onsuccess = function (event) {     console.log(event);   };    // 处理失败用例   query.onerror = function (event) {     console.log(event.target.errorCode);   }    // 事务完成后关闭数据库   txn.oncomplete = function () {     db.close();   }; }

一旦创建了插入函数,请求的 onsuccess 事件处理程序就可以用来插入更多的记录。

request.onsuccess = (event) => {    const db = event.target.result;    insertUser(db, {      email: 'john.doe@outlook.com',      firstName: 'John',      lastName: 'Doe',    });    insertUser(db, {      email: 'ann.doe@gmail.com',      firstName: 'Ann',      lastName: 'Doe'    }); };

在IndexedDB上可以执行许多操作,其中一些如下:

  • 通过key从对象存储中读取/搜索数据

  • 按index从对象存储中读取/搜索数据

  • 更新记录数据

  • 删除记录

  • 从数据库的先前版本等进行迁移

IndexedDB的功能

IndexedDB提供了许多特殊的功能,这是其他浏览器存储无法实现的,下面简要说明一些功能。

具有异步API

这使执行昂贵的操作而不会阻塞UI线程,并为用户提供了更好的体验。

支持事务以确保可靠性

如果一个步骤失败,则事务将被取消,数据库将回滚到先前的状态。

支持版本控制

你可以在创建数据库时对其进行版本控制,并在需要时对其进行升级。在IndexedDB中也可以从旧版本迁移到新版本。

私有域

数据库是一个域的私有数据库,因此任何其他网站都不能访问其他网站的 IndexedDB 存储。这也就是所谓的同源策略。

IndexedDB的局限性

到目前为止,IndexedDB似乎很有希望用于客户端存储。然而,有一些值得注意的限制。

  • 即使有现代浏览器的支持,但IE等浏览器并没有完全支持。

怎么使用IndexedDB

  • Firefox 在私人浏览模式下完全禁用 IndexedDB - 这可能导致你的应用程序在通过隐身窗口访问时发生故障。

IndexedDB是否适合你的应用程序?

基于 IndexedDB 提供的许多功能,这个百万美元问题的答案可能是 Yes!然而,在下结论之前,请问自己以下问题。

你的应用程序需要脱机访问吗?

  • 你是否需要在客户端存储大量数据?

  • 你是否需要快速查找/搜索大量数据中的数据?

  • 你的应用程序是否使用IndexedDB支持的浏览器访问客户端存储?

  • 你是否需要存储各种类型的数据,包括javascript对象?

  • 从客户端存储进行写入/读取是否需要非阻塞?

如果对上述所有问题的回答均为“是”,则IndexedDB是你的最佳选择。但如果不需要这样的功能,你不妨选择像 localStorage  这样的存储方法,因为它提供了广泛的浏览器应用,并且具有易于使用的api

总结

当我们考虑所有的客户端存储机制时,IndexedDB是一个明显的赢家。我们来看看不同客户端存储方式的总结比较。

怎么使用IndexedDB

感谢各位的阅读,以上就是“怎么使用IndexedDB”的内容了,经过本文的学习后,相信大家对怎么使用IndexedDB这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

您可能感兴趣的文档:

--结束END--

本文标题: 怎么使用IndexedDB

本文链接: https://lsjlt.com/news/61852.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么使用IndexedDB
    这篇文章主要讲解了“怎么使用IndexedDB”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用IndexedDB”吧!深入研究IndexedDB AP...
    99+
    2024-04-02
  • 怎么在HTML5 客户端中使用IndexedDB数据库
    今天就跟大家聊聊有关怎么在HTML5 客户端中使用IndexedDB数据库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。IndexedDB介绍IndexedDB是一种能在浏览器中持久...
    99+
    2023-06-09
  • Html5中本地存储IndexedDB怎么用
    这篇文章将为大家详细讲解有关Html5中本地存储IndexedDB怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。IndexedDB 是一种低级API,用于客户端存储...
    99+
    2024-04-02
  • 如何在HTML5中使用indexedDB 数据库
    如何在HTML5中使用indexedDB 数据库?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。连接数据库一个网站可以有多个 indexedDB 数据库,但每个数据库的名称是唯一...
    99+
    2023-06-09
  • HTML5本地存储之IndexedDB有什么用
    这篇文章主要介绍HTML5本地存储之IndexedDB有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!IndexedDB 是一种低级API,用于客户端存储大量结构化数据(包括,...
    99+
    2024-04-02
  • 浏览器数据库IndexedDB是怎样入门的
    本篇文章为大家展示了浏览器数据库IndexedDB是怎样入门的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、概述随着浏览器的功能不断增强,越来越多的网站开始考虑...
    99+
    2024-04-02
  • myeclipse怎么使用
    myeclipse怎么使用?首先双击打开软件,主界面如图二所示然后点击文件---->新建---->Java项目在项目名那里输入你要新建的项目名称,名称随意。名称输入完之后直接点击完成...
    99+
    2022-02-23
    java教程 myeclipse
  • 怎么使用SQLite3
    这篇文章主要讲解了“怎么使用SQLite3”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用SQLite3”吧!开始使用这个功能强大且通用的数据库吧。应...
    99+
    2024-04-02
  • 怎么使用hanganalyze
    本篇内容主要讲解“怎么使用hanganalyze”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用hanganalyze”吧!hanganalyze 和sy...
    99+
    2024-04-02
  • 怎么使用pg_rewind
    本篇内容主要讲解“怎么使用pg_rewind”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用pg_rewind”吧!pg_rewind  是po...
    99+
    2024-04-02
  • 怎么使用DBV
    这篇文章主要介绍“怎么使用DBV”,在日常操作中,相信很多人在怎么使用DBV问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用DBV”的疑惑有所帮助!接下来,请跟着小编一...
    99+
    2024-04-02
  • 怎么使用RMAN
    本篇内容介绍了“怎么使用RMAN”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!RMAN的备份脚本可以存储在...
    99+
    2024-04-02
  • 怎么使用MindMaster
    本篇内容主要讲解“怎么使用MindMaster”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用MindMaster”吧!MindMaster可谓是思维导图...
    99+
    2024-04-02
  • Redis怎么使用
    这篇文章给大家分享的是有关Redis怎么使用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、Redis简介 什么是Redis?全称:REmote DIctionary Serv...
    99+
    2024-04-02
  • logminer怎么使用
    这篇文章主要讲解了“logminer怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“logminer怎么使用”吧! Log...
    99+
    2024-04-02
  • MySQL怎么使用
    这篇文章主要介绍MySQL怎么使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、SQL速成  以下是一些重要的SQL快速参考,有关SQL的语法和在标准SQL上增加的特性,请查询M...
    99+
    2024-04-02
  • 怎么使用NTVS
    本篇内容介绍了“怎么使用NTVS”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!就在你认为Redmond不可...
    99+
    2024-04-02
  • 怎么使用Json
    本篇内容主要讲解“怎么使用Json”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用Json”吧!Json一般用在少量的数据处理。因为格式简单,操作方便,而...
    99+
    2024-04-02
  • 怎么使用Dart
    本篇内容介绍了“怎么使用Dart”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!下面是简单的Hello Wo...
    99+
    2024-04-02
  • section怎么使用
    今天小编给大家分享一下section怎么使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作