最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 如何使用IndexedDB —浏览器上的NoSQL数据库

    正文概述 掘金(杭州程序员张张)   2021-02-26   718

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

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

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

    如何使用IndexedDB —浏览器上的NoSQL数据库

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

    • 为什么我们需要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对象等)。它使用对象存储在内部保存数据。

    提供查找界面

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

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

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

    应用状态可以存储

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

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

    IndexedDB的结构

    如何使用IndexedDB —浏览器上的NoSQL数据库

    我们如何在我们的应用程序中使用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 —浏览器上的NoSQL数据库
    • Firefox 在私人浏览模式下完全禁用 IndexedDB - 这可能导致你的应用程序在通过隐身窗口访问时发生故障。

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

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

    • 你的应用程序需要脱机访问吗?
    • 你是否需要在客户端存储大量数据?
    • 你是否需要快速查找/搜索大量数据中的数据?
    • 你的应用程序是否使用IndexedDB支持的浏览器访问客户端存储?
    • 你是否需要存储各种类型的数据,包括JavaScript对象?
    • 从客户端存储进行写入/读取是否需要非阻塞?

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

    总结

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

    CookiesWeb StorageIndexedDB
    存储具有键值、数据值对的小型查询表只有字符
    串键、值存储
    对象存储,可以存储任何类型的数据,包括对象容量4KB5MB-25MB50MB以上索引不支持不支持支持API调用类型同步同步异步操作性能直接执行直接执行事务学习曲线

    希望你对IndexedDB及其好处有一个清晰的认识。


    翻译自:blog.bitsrc.io,作者:Viduni Wickramarachchi


    起源地下载网 » 如何使用IndexedDB —浏览器上的NoSQL数据库

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元