当前位置: 首页 > 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.它允许开发…...

Android 好的开源库

1. 权限请求框架 GitHub - getActivity/XXPermissions: Android 权限请求框架&#xff0c;已适配 Android 14 2. 下载框架 GitHub - lingochamp/okdownload: A Reliable, Flexible, Fast and Powerful download engine....

Go 语言结构

Go 语言结构 Go 语言,也称为 Golang,是一种由 Google 开发和支持的静态类型、编译型编程语言。它于 2009 年首次发布,旨在提高多核处理器、网络资源和大型代码库的性能。Go 语言以其简洁的语法、并发支持和强大的标准库而闻名,特别适合构建高性能的网络服务和分布式系统。…...

【漆学军】MT5几个重要类库的使用例子

MT5编程&#xff0c;有两种方式&#xff0c;一种是函数式编程&#xff0c;一种是面向对象编程。 面向对象编程&#xff0c;会让我们编写代码变得非常简单。 面向对象编程&#xff0c;主要是要熟悉4个类库。 #include <Trade\PositionInfo.mqh> #include <Trade\Tra…...

在 Ubuntu 24.04.1 LTS (WSL) 中使用 openssl 生成 keybox.xml

看到“生成 keybox.xml”&#xff0c;大概率都会联想到 PIF 和 Tricky Store。这里就不多解释它们的用途了。最近在网上看到生成非 AOSP keybox 的教程&#xff0c;在这里做一些补充&#xff0c;并将代码打包成一个 Python 脚本。 参考自&#xff1a; Idea 提供者&#xff1a…...

【JavaSE基础】第十六章:IO流

一、理解 1.简单而言&#xff1a;流就是内存与存储设备之间传输数据的通道、管道。 2.流的分类&#xff1a; (1) 按方向 ( 以 JVM 虚拟机为参照物 ) 【重点】 输入流&#xff1a;将< 存储设备 > 中的内容读入到 < 内存 > 中。 输…...

常见漏洞—SSRF_FastCGI

FastCGI协议 简介 Fast CGI源自旧版本的CGI 路由/结构图 # 访问url --> 浏览器生成HTTP请求报文 --> web server解析请求&#xff08;例如nginx&#xff09; web server 是内容的分发者 当访问静态页面时&#xff0c;web server 会直接返回资源&#xff0c;例如index.htm…...

LeetCode 283.移动零(超简单讲解)

283.移动零 题目示例示例1示例2 解题思路快慢指针实现设计 详细代码 题目 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 示例 示例1 …...

GIS原理及应用、地理坐标系与投影坐标系

文章目录 一、GIS定义1.1 地理信息系统1.2 建模1.3 相关教程1.4 GIS前沿方向 二、GIS数据格式2.1 矢量2.2 栅格2.3 矢量与栅格的区别 三、GIS数据组织3.1 抽象3.2 分层3.3 栅格与切片 四、坐标系4.1 坐标系简介4.2 大地坐标系GCS4.3 投影坐标系PCS4.4 投影变换 五、空间数据库与…...

用github镜像加速, --recursive还是去github站怎么处理?

小伙伴们大多碰到过github抽风的情况&#xff0c;时通时断&#xff0c;时快时慢&#xff0c;非常考验心情。 以前碰到连不上的时候&#xff0c;我大多就是在gitee和gitcode网站找一下镜像&#xff0c;找到后直接git clone 新地址即可。但是碰到 --recursive的时候就不行了&…...

ctfshow-web 151-170-文件上传

151. 我们首先想到就是上传一句话木马。但是看源代码限制了png。 &#xff08;1&#xff09;改前端代码。 这里是前端限制了上传文件类型&#xff0c;那我们就改一下就好了嘛,改成php。 这里直接修改不行&#xff0c;给大家推荐一篇简短文章&#xff0c;大家就会了&#xff08…...