当前位置: 首页 > news >正文

LocalForage 使用指南:统一管理 LocalStorage、WebSQL 和 IndexedDB

前言

在前端开发中,客户端数据存储是一个至关重要的环节。无论是用户偏好设置、缓存内容,还是表单数据,都需要一个高效、可靠的存储方案。浏览器原生提供的 LocalStorage、SessionStorage 和 IndexedDB 等 API 虽然功能强大,但使用起来相对复杂,特别是在处理异步操作时。LocalForage 作为一个流行的 JavaScript 库,通过统一接口和异步操作,极大简化了本地存储的使用体验,同时确保了跨浏览器的兼容性。本文将详细介绍 LocalForage 的使用方式,并展示其在实际开发中的应用。

为什么选择 LocalForage?

  1. 统一接口:LocalForage 封装了 LocalStorage、WebSQL 和 IndexedDB,提供一个统一的 API,极大简化了数据存储的逻辑。
  2. 异步操作:LocalForage 的所有方法都是异步的,使用了 Promise,大大提高了性能并避免了阻塞主线程。
  3. 跨浏览器兼容:LocalForage 具有良好的跨浏览器兼容性,即使在老旧浏览器中也能正常工作。

使用步骤?

安装

你可以通过 npm 或者直接引用 CDN 链接来使用 LocalForage。

使用 npm 安装:
npm install localforage

通过 CDN 引用:

基本用法

下面是一些常用的 LocalForage 操作示例。

初始化

首先,我们需要创建一个 LocalForage 实例并进行初始化配置。

localforage.config({driver      : localforage.INDEXEDDB, // 首选的存储方式name        : 'myApp',               // 数据库名称version     : 1.0,                   // 数据库版本storeName   : 'keyvaluepairs',       // 存储空间名称description : 'some description'     // 数据库描述
});
存储数据

我们可以使用 setItem 方法将数据存储到 LocalForage 中。

localforage.setItem('key', 'value').then(function() {console.log('数据已存储');
}).catch(function(err) {console.log('存储失败:', err);
});
检索数据

通过 getItem 方法可以检索存储的数据。

localforage.getItem('key').then(function(value) {console.log('检索到的数据:', value);
}).catch(function(err) {console.log('检索失败:', err);
});
删除数据

使用 removeItem 方法删除指定的存储项。

localforage.removeItem('key').then(function() {console.log('数据已删除');
}).catch(function(err) {console.log('删除失败:', err);
});
清空存储

clear 方法可以清空 LocalForage 中的所有数据。

localforage.clear().then(function() {console.log('所有数据已清空');
}).catch(function(err) {console.log('清空失败:', err);
});
获取存储的键列表

使用 keys 方法获取所有存储的键。

localforage.keys().then(function(keys) {console.log('存储的键:', keys);
}).catch(function(err) {console.log('获取键列表失败:', err);
});

进阶用法

在了解了 LocalForage 的基本用法后,我们可以进一步探讨一些高级特性和技巧,以便更好地在项目中使用它。

自定义驱动器

除了内置的 LocalStorage、WebSQL 和 IndexedDB 驱动器,LocalForage 还允许你定义自己的驱动器。这对于需要特殊存储需求的项目特别有用。

const customDriver = {_driver: 'customDriver',_initStorage: function(options) {// 自定义初始化逻辑},getItem: function(key, callback) {// 自定义获取数据逻辑},setItem: function(key, value, callback) {// 自定义存储数据逻辑},removeItem: function(key, callback) {// 自定义删除数据逻辑},clear: function(callback) {// 自定义清空数据逻辑},length: function(callback) {// 自定义获取存储长度逻辑},key: function(n, callback) {// 自定义获取键名逻辑},keys: function(callback) {// 自定义获取所有键名逻辑},iterate: function(iteratorCallback, successCallback) {// 自定义迭代逻辑}
};

// 定义并使用自定义驱动器

localforage.defineDriver(customDriver).then(function() {return localforage.setDriver('customDriver');
}).then(function() {// 自定义驱动器已启用
});

使用回调函数

尽管 Promises 非常方便,但有时你可能需要使用回调函数。LocalForage 支持回调函数作为异步操作的替代方案。

// 使用回调函数存储数据

localforage.setItem('key', 'value', function(err) {if (err) {console.log('存储失败:', err);} else {console.log('数据已存储');}
});

// 使用回调函数检索数据

localforage.getItem('key', function(err, value) {if (err) {console.log('检索失败:', err);} else {console.log('检索到的数据:', value);}
});

使用 Blob 和 File 对象

LocalForage 支持存储和检索复杂的数据类型,包括 Blob 和 File 对象。这使得它特别适合存储图片、音频文件等大型二进制数据。

// 存储 Blob 对象

const blob = new Blob(['Hello, world!'], { type: 'text/plain' });
localforage.setItem('blobKey', blob).then(function() {console.log('Blob 已存储');
});

// 检索 Blob 对象

localforage.getItem('blobKey').then(function(blob) {console.log('检索到的 Blob:', blob);
});

设置驱动顺序

你可以通过 setDriver 方法设置驱动的优先顺序。如果第一个驱动不可用,LocalForage 将尝试使用下一个驱动。

localforage.setDriver([localforage.INDEXEDDB,localforage.WEBSQL,localforage.LOCALSTORAGE
]).then(function() {console.log('驱动设置成功');
}).catch(function(err) {console.log('驱动设置失败:', err);
});

错误处理

在实际开发中,处理错误是不可避免的。LocalForage 提供的 Promise 和回调函数都能很好地处理错误。

localforage.setItem('key', 'value').catch(function(err) {console.error('存储过程中出错:', err);
});localforage.getItem('key', function(err, value) {if (err) {console.error('检索过程中出错:', err);} else {console.log('检索到的数据:', value);}
});

使用 LocalForage 与框架集成

LocalForage 可以轻松地与 Vue、React 等前端框架集成。例如,在 Vue 中,你可以创建一个插件来全局使用 LocalForage。

在 Vue 中集成 LocalForage:

import Vue from 'vue';
import localforage from 'localforage';localforage.config({driver      : localforage.INDEXEDDB,name        : 'myVueApp',storeName   : 'keyvaluepairs'
});Vue.prototype.$localforage = localforage;new Vue({el: '#app',mounted() {this.$localforage.setItem('hello', 'world').then(() => {return this.$localforage.getItem('hello');}).then((value) => {console.log('从 LocalForage 中检索到的值:', value);});}
});

总结

总之,LocalForage 是一个功能强大且灵活的客户端存储解决方案,它通过简单的 API 和强大的功能,使开发者能够更加高效地管理客户端数据存储。无论是面向小型应用还是大型项目,LocalForage 都提供了充分的支持,确保数据存储的稳定性和兼容性。

相关文章:

LocalForage 使用指南:统一管理 LocalStorage、WebSQL 和 IndexedDB

前言 在前端开发中,客户端数据存储是一个至关重要的环节。无论是用户偏好设置、缓存内容,还是表单数据,都需要一个高效、可靠的存储方案。浏览器原生提供的 LocalStorage、SessionStorage 和 IndexedDB 等 API 虽然功能强大,但使…...

代码随想录算法训练营第五天-哈希-242.有效的字母异位词

这道题的总体感觉不是很难&#xff0c;但是其完成的思想还是很有趣的利用数据下标来代表字母序列然后遍历两个字符串每个字符&#xff0c;给对应字母下标的数组中一个自增&#xff0c;另一个自减通过查看最后的数组内容是不是0&#xff0c;来判断是不是异位词 #include <io…...

学习maven(maven 项目模块化,继承,聚合)

前言 本篇博客的核心&#xff1a;理解maven 项目模块化&#xff0c;继承&#xff0c;聚合 的含义 maven 项目模块化 含义 maven项目模块化&#xff1a;使用maven 构建项目&#xff0c;管理项目的方式&#xff0c;我们可以将maven项目根据内在的关系拆分成很多个小项目【模块】…...

KDD 2025预讲会:10位一作的论文分享与话题思辨|12月18日全天直播

点击蓝字 关注我们 AI TIME欢迎每一位AI爱好者的加入&#xff01; 圆桌思辨&#xff1a;一作们的KDD 2025投稿经验分享与热点探讨 1. KDD 2025 与往年相比有哪些新变化&#xff1f;两次投稿周期的新规则有哪些影响&#xff1f; 2. 第一篇KDD的工作是如何成功被接收的&#xff1…...

掌握特征提取:机器学习中的 PCA、t-SNE 和 LDA模型

文章目录 一、说明二、既然有 PCA 技术降维&#xff0c;为什么还要学习 t-SNE&#xff1f;2.1 t-SNE的核心思想&#xff1a;2.2 保持点之间的局部关系有什么意义&#xff1f;2.3 t-SNE 的几何直觉&#xff1a; 三、t-SNE 的数学公式&#xff1a;四、目标函数&#xff1a;五、梯…...

JAVA基础:注释

JAVA基础:注释 作用 使得代码中的一段文本不被执行,起到解释说明的作用。 分类 JAVA中的注释有三种: 单行注释 //单行注释多行注释 /* 多 行 注 释 */文档注释 /***@deprecated comments* @author lhy*/文档注释可以添加一些参数作为说明。 有趣的代码注释 卡车/* * *…...

从源码构建安装Landoop kafka-connect-ui

背景 部署Landoop kafka-connect-ui最简单的办法还是通过docker来部署&#xff0c;我们之前的kafka-connect-ui就是通过docker部署的&#xff0c;但是&#xff0c;最近发现个问题&#xff1a;当使用docker部署且防火墙使用的是firewalld的情况下&#xff0c;就会出现端口冲突。…...

【自动驾驶】Ubuntu22.04源码安装Autoware Core/Universe

【自动驾驶】Ubuntu22.04源码安装Autoware Core/Universe 官方源码安装教程前置条件安装ROS2 Humble安装Autoware Core/Universe配置开发环境配置工作空间设置控制台 官方源码安装教程 链接&#xff1a;https://autowarefoundation.github.io/autoware-documentation/main/ins…...

使用Nexus3搭建npm私有仓库

一、npm介绍 npm的全称是Node Package Manager&#xff0c;它是一个开放源代码的命令行工具&#xff0c;用于安装、更新和管理Node.js模块。npm是Node.js的官方模块管理器&#xff0c;它允许用户从一个集中的仓库中下载和安装公共的Node.js模块&#xff0c;并将这些模块集成到…...

OpenHarmony和OpenVela的技术创新以及两者对比

两款有名的国内开源操作系统&#xff0c;OpenHarmony&#xff0c;OpenVela都非常的优秀。本文对二者的创新进行一个简要的介绍和对比。 一、OpenHarmony OpenHarmony具有诸多有特点的技术突破和重要贡献&#xff0c;以下是一些主要方面&#xff1a; 架构设计创新 分层架构…...

【LeetCode每日一题】Leetcode 1071.字符串的最大公因子

Leetcode 1071.字符串的最大公因子 题目描述&#xff1a; 对于字符串 s 和 t&#xff0c;只有在 s t t t … t t&#xff08;t 自身连接 1 次或多次&#xff09;时&#xff0c;我们才认定 t 能除尽 s。 给定两个字符串 str1 和 str2 。返回 最长字符串 x&#xff0c;要…...

《C++:计算机视觉图像识别与目标检测算法优化的利器》

在当今科技飞速发展的时代&#xff0c;计算机视觉领域正经历着前所未有的变革与突破。图像识别和目标检测作为其中的核心技术&#xff0c;广泛应用于安防监控、自动驾驶、智能医疗等众多领域&#xff0c;其重要性不言而喻。而 C语言&#xff0c;凭借其卓越的性能、高效的资源控…...

大模型的构建与部署(2)——数据清洗

版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl1. 数据清洗的必要性与影响 1.1 数据清洗对模型性能的影响 数据清洗是数据预处理的关键步骤,对于模型训练的性能和准确性有着直接的影响。原始数据中的缺失值、重复值、异常值以及数据格式不一致…...

试题转excel;word转excel;大风车excel

一、问题描述 一名教师朋友&#xff0c;偶尔会需要整理一些高质量的题目到excel中 以往都是手动复制搬运&#xff0c;几百道题几乎需要一个下午的时间 关键这些事&#xff0c;枯燥无聊费眼睛&#xff0c;实在是看起来就很蠢的工作 就想着做一个工具&#xff0c;可以自动处理…...

微信小程序webview和小程序通讯

1.背景介绍 1.1需要在小程序嵌入vr页面&#xff0c;同时在vr页面添加操作按钮与小程序进行通信交互 1.2开发工具&#xff1a;uniapp开发小程序 1.3原型图 功能&#xff1a;.点击体验官带看跳转小程序的体验官带看页面 功能&#xff1a;点击立即咨询唤起小程序弹窗打电话 2.…...

ChatGPT大模型 创作高质量文案的使用教程和案例

引言 随着人工智能技术的飞速发展,大语言模型如 ChatGPT 在创作文案、生成内容方面展现出了强大的能力。无论是个人用户还是企业用户,都可以利用 ChatGPT 提高工作效率、激发创意、甚至解决实际问题。本文将详细介绍 ChatGPT 如何帮助创作各类高质量文案,并通过具体案例展示…...

Vue Web开发(八)

1. VueWeb面包屑和tag的布局 本章节完成VueWeb面包屑和tag的布局&#xff0c;并且与左侧菜单联系&#xff0c;涉及组件间通信。 1.1. 页面创建 &#xff08;1&#xff09;首先我们先完成每个页面的路由&#xff0c;之前已经有home页面和user页面&#xff0c;缺少mail页面和其…...

element-ui实现table表格的嵌套(table表格嵌套)功能实现

最近在做电商类型的官网&#xff0c;希望实现的布局如下&#xff1a;有表头和表身&#xff0c;所以我首先想到的就是table表格组件。 表格组件中常见的就是&#xff1a;标题和内容一一对应&#xff1a; 像效果图中的效果&#xff0c;只用基础的表格布局是不行的&#xff0c;因…...

【考前预习】4.计算机网络—网络层

往期推荐 【考前预习】3.计算机网络—数据链路层-CSDN博客 【考前预习】2.计算机网络—物理层-CSDN博客 【考前预习】1.计算机网络概述-CSDN博客 目录 1.网络层概述 2.网络层提供的两种服务 3.分类编址的IPV4 4.无分类编址的IPV4—CIDR 5.IPV4地址应用规划 5.1使用定长子…...

【java】MDC

目录 1. 说明2. 作用3. 使用4. 与TraceID的关系5. 注意事项 1. 说明 1.MDC&#xff08;Mapped Diagnostic Context&#xff09;是一个用于在多线程环境中追踪和传递日志上下文信息的机制。2.映射诊断环境。3.MDC是一个线程本地的、可维护的、可传递的上下文环境。4.它允许开发…...

Python|GIF 解析与构建(5):手搓截屏和帧率控制

目录 Python&#xff5c;GIF 解析与构建&#xff08;5&#xff09;&#xff1a;手搓截屏和帧率控制 一、引言 二、技术实现&#xff1a;手搓截屏模块 2.1 核心原理 2.2 代码解析&#xff1a;ScreenshotData类 2.2.1 截图函数&#xff1a;capture_screen 三、技术实现&…...

解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八

现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet&#xff0c;点击确认后如下提示 最终上报fail 解决方法 内核升级导致&#xff0c;需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...

线程与协程

1. 线程与协程 1.1. “函数调用级别”的切换、上下文切换 1. 函数调用级别的切换 “函数调用级别的切换”是指&#xff1a;像函数调用/返回一样轻量地完成任务切换。 举例说明&#xff1a; 当你在程序中写一个函数调用&#xff1a; funcA() 然后 funcA 执行完后返回&…...

关于nvm与node.js

1 安装nvm 安装过程中手动修改 nvm的安装路径&#xff0c; 以及修改 通过nvm安装node后正在使用的node的存放目录【这句话可能难以理解&#xff0c;但接着往下看你就了然了】 2 修改nvm中settings.txt文件配置 nvm安装成功后&#xff0c;通常在该文件中会出现以下配置&…...

Mac软件卸载指南,简单易懂!

刚和Adobe分手&#xff0c;它却总在Library里给你写"回忆录"&#xff1f;卸载的Final Cut Pro像电子幽灵般阴魂不散&#xff1f;总是会有残留文件&#xff0c;别慌&#xff01;这份Mac软件卸载指南&#xff0c;将用最硬核的方式教你"数字分手术"&#xff0…...

均衡后的SNRSINR

本文主要摘自参考文献中的前两篇&#xff0c;相关文献中经常会出现MIMO检测后的SINR不过一直没有找到相关数学推到过程&#xff0c;其中文献[1]中给出了相关原理在此仅做记录。 1. 系统模型 复信道模型 n t n_t nt​ 根发送天线&#xff0c; n r n_r nr​ 根接收天线的 MIMO 系…...

SQL慢可能是触发了ring buffer

简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...

关于easyexcel动态下拉选问题处理

前些日子突然碰到一个问题&#xff0c;说是客户的导入文件模版想支持部分导入内容的下拉选&#xff0c;于是我就找了easyexcel官网寻找解决方案&#xff0c;并没有找到合适的方案&#xff0c;没办法只能自己动手并分享出来&#xff0c;针对Java生成Excel下拉菜单时因选项过多导…...

快速排序算法改进:随机快排-荷兰国旗划分详解

随机快速排序-荷兰国旗划分算法详解 一、基础知识回顾1.1 快速排序简介1.2 荷兰国旗问题 二、随机快排 - 荷兰国旗划分原理2.1 随机化枢轴选择2.2 荷兰国旗划分过程2.3 结合随机快排与荷兰国旗划分 三、代码实现3.1 Python实现3.2 Java实现3.3 C实现 四、性能分析4.1 时间复杂度…...

【java面试】微服务篇

【java面试】微服务篇 一、总体框架二、Springcloud&#xff08;一&#xff09;Springcloud五大组件&#xff08;二&#xff09;服务注册和发现1、Eureka2、Nacos &#xff08;三&#xff09;负载均衡1、Ribbon负载均衡流程2、Ribbon负载均衡策略3、自定义负载均衡策略4、总结 …...