uni-app——数据缓存API

数据缓存API

在 uni-app 开发中,数据缓存 API 起着重要作用,它能够将需要的数据保存到本地,同时也提供了获取本地缓存数据、移除缓存数据以及清理缓存数据的功能。在实际项目里,数据缓存 API 常被用于存储会员登录状态信息、购物车数据、用户浏览历史记录等。这些数据若频繁从服务器获取,会增加网络开销和响应时间,使用本地缓存能有效提升应用性能和用户体验。

将数据缓存到本地

在 uni-app 中,有两种方式可以将数据缓存到本地,分别是uni.setStorage(OBJECT)和uni.setStorageSync(KEY, DATA)。

  1. uni.setStorage(OBJECT)
    • 此方法以异步方式将数据存储在本地缓存指定的key中,会覆盖掉key原来对应的内容。
    • 参数说明
      • key(必填):本地缓存中指定的key,通过这个key来唯一标识缓存的数据。
      • data(必填):需要缓存的内容,这里只支持原生类型(如字符串、数字、布尔值等)和能通过JSON.stringify序列化的对象。
      • success、fail、complete:这三个是回调函数。success在数据成功缓存到本地后触发;fail在缓存过程中出现错误时触发;complete无论缓存操作成功与否,在操作结束时都会执行。
    • 示例代码
let userInfo = {name: '张三', age: 25};
uni.setStorage({key: 'user_info',data: userInfo,success: function () {console.log('数据缓存成功');},fail: function (err) {console.log('数据缓存失败', err);},complete: function () {console.log('缓存操作结束');}
});
  1. uni.setStorageSync(KEY, DATA)
    • 该方法以同步方式将数据存储在本地缓存指定的key中,同样会覆盖掉key原来对应的内容。相较于异步缓存方式,它的代码编写更为简洁。
    • 参数说明
      • key(必填):本地缓存中指定的key。
      • data(必填):需要缓存的内容,要求与uni.setStorage中的data一致,只支持原生类型和能通过JSON.stringify序列化的对象。
    • 同步与异步的区别

同步:等本地缓存成功后,再执行下面的程序

异步:不需要等待本地缓存成功,就可以执行下面的程序

在数据缓存比较耗时的情况下,可以使用异步方式进行数据缓存。

    • 示例代码
let userInfo = {name: '李四', age: 30};
try {uni.setStorageSync('user_info', userInfo);console.log('数据同步缓存成功');
} catch (err) {console.log('数据同步缓存失败', err);
}

不论是同步还是异步方式,本质上都是以 “key/value” 的形式存储数据的。

获取本地缓存数据

uni-app 为获取本地缓存数据提供了 4 个 API,分别从不同角度满足开发者获取缓存数据的需求。

  1. uni.getStorage(OBJECT)
    • 此方法以异步方式从本地缓存中获取key对应的数据。
    • 参数说明
      • key(必填):本地缓存中指定的key,通过这个key来获取对应的数据。
      • success、fail、complete:回调函数。success在成功获取到数据时触发,返回的数据在回调函数的参数中;fail在获取数据失败时触发;complete在操作结束时执行。
    • 示例代码
uni.getStorage({key: 'user_info',success: function (res) {console.log('获取数据成功', res.data);},fail: function (err) {console.log('获取数据失败', err);},complete: function () {console.log('获取数据操作结束');}
});
  1. uni.getStorageSync(KEY)
    • 这是一个同步的 API,只有一个参数key。它从本地缓存中以同步方式获取key对应的数据。
    • 示例代码
try {let userInfo = uni.getStorageSync('user_info');console.log('同步获取数据成功', userInfo);
} catch (err) {console.log('同步获取数据失败', err);
}
  1. uni.getStorageInfo(OBJECT)
    • 该方法以异步方式获取本地所有key的集合。
    • 参数说明
      • success、fail、complete:回调函数。success回调函数的参数有keys(本地所有key组成的数组)、currentSize(当前本地缓存占用的空间大小)、limitSize(本地缓存允许的最大空间大小)。通过这些参数,开发者可以了解本地缓存的整体情况。
    • 示例代码
uni.getStorageInfo({success: function (res) {console.log('获取本地缓存信息成功', res.keys);console.log('当前缓存大小', res.currentSize);console.log('缓存限制大小', res.limitSize);},fail: function (err) {console.log('获取本地缓存信息失败', err);},complete: function () {console.log('获取本地缓存信息操作结束');}
});
  1. uni.getStorageInfoSync()
    • 此方法以同步方式获取本地所有key的集合。
    • 示例代码
try {let storageInfo = uni.getStorageInfoSync();console.log('同步获取本地缓存信息成功', storageInfo.keys);console.log('当前缓存大小', storageInfo.currentSize);console.log('缓存限制大小', storageInfo.limitSize);
} catch (err) {console.log('同步获取本地缓存信息失败', err);
}

前两个 API(uni.getStorage和uni.getStorageSync)用于从指定key获得缓存数据,而后两个(uni.getStorageInfo和uni.getStorageInfoSync)则是获取本地所有key的集合。

清理本地缓存数据

在开发中,有时需要清理本地缓存数据,uni-app 提供了相应的 API 来实现这一功能。

  1. uni.removeStorage(OBJECT)
    • 此方法以异步方式从本地缓存中移除指定key。
    • 参数说明
      • key:本地缓存中要移除的key。
      • success、fail、complete:回调函数。success在成功移除key对应的数据后触发;fail在移除过程中出现错误时触发;complete在操作结束时执行。
    • 示例代码
uni.removeStorage({key: 'user_info',success: function () {console.log('数据移除成功');},fail: function (err) {console.log('数据移除失败', err);},complete: function () {console.log('移除数据操作结束');}
});
  1. uni.removeStorageSync(KEY)
    • 该方法以同步方式从本地缓存中移除指定的key。
    • 示例代码
try {uni.removeStorageSync('user_info');console.log('数据同步移除成功');
} catch (err) {console.log('数据同步移除失败', err);
}
  1. uni.clearStorage () 和 uni.clearStorageSync ()
    • 这两个方法用来清理本地所有缓存数据。uni.clearStorage()采用异步方式,uni.clearStorageSync()采用同步方式。
    • 示例代码(异步)
uni.clearStorage({success: function () {console.log('所有缓存数据异步清理成功');},fail: function (err) {console.log('所有缓存数据异步清理失败', err);},complete: function () {console.log('异步清理缓存操作结束');}
});
  • 示例代码(同步)
try {uni.clearStorageSync();console.log('所有缓存数据同步清理成功');
} catch (err) {console.log('所有缓存数据同步清理失败', err);
}

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

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

相关文章

突破时空边界:Java实时流处理中窗口操作与时间语义的深度重构

一、流处理范式的革命性演进 在数字化浪潮的推动下,数据处理范式正经历着从批量到实时的根本性转变。这种转变不仅改变了数据处理的时效性特征,更重新定义了时间维度在计算模型中的战略地位。Apache Flink的统计数据显示,现代流处理系统每秒…

【2025 深圳大学-腾讯云程序设计竞赛(热身赛)】题解

比赛链接 A. Cloud Studio的共享连接 题目大意 && Solution 给定 T T T 组长度均为 12 12 12 的字符串 s s s。 对每个 s s s,将其按从左到右的顺序两两分组形成 6 6 6 个 A S C I I \rm{ASCII} ASCII 码,对这 6 6 6 个 A S C I I \…

APScheduler - 用户指南

本文翻译整理自:https://apscheduler.readthedocs.io/en/3.x/userguide.html 文章目录 一、安装 APScheduler二、代码示例三、基本概念四、选择合适的 scheduler, job store(s), executor(s) and trigger(s)五、配置调度器方法 1:方法 2:方法 3: 六、启动调度器七、…

vue3:十一、主页面布局(优化页面跳转方式)

:router"true" 一、参考文章 vue3:十一、主页面布局(实现基本左侧菜单右侧内容效果)-CSDN博客 参考上述文章可知,页面跳转是通过在js中定义的菜单中携带的path,然后通过菜单的点击事件完成的跳转,现在可以进行优化,直…

每日一题--C与C++的差别

C与C的差别 1. 编程范式 C 纯 过程式编程语言,强调函数和结构化编程。 代码通过函数和顺序步骤组织,适合底层系统开发。 C 支持 多范式编程: 过程式编程 面向对象编程(OOP)(类、继承、多态) …

Etcd 服务搭建

💢欢迎来到张胤尘的开源技术站 💥开源如江河,汇聚众志成。代码似星辰,照亮行征程。开源精神长,传承永不忘。携手共前行,未来更辉煌💥 文章目录 Etcd 服务搭建预编译的二进制文件安装下载 etcd 的…

玩转C#函数:参数、返回值与游戏中的攻击逻辑封装

Langchain系列文章目录 01-玩转LangChain:从模型调用到Prompt模板与输出解析的完整指南 02-玩转 LangChain Memory 模块:四种记忆类型详解及应用场景全覆盖 03-全面掌握 LangChain:从核心链条构建到动态任务分配的实战指南 04-玩转 LangChai…

WebRTC建立Description的通信的实际的原理

一、正确流程的核心逻辑 // 发送端正确代码示例 const senderPC new RTCPeerConnection();// 生成Offer时立即开始收集候选 ✅ senderPC.createOffer().then(offer > {await senderPC.setLocalDescription(offer); // 触发icecandidate事件sendToReceiver(offer); });// …

EmbodiedSAM:在线实时3D实例分割,利用视觉基础模型实现高效场景理解

2025-02-12,由清华大学和南洋理工大学的研究团队开发 一种名为 EmbodiedSAM(ESAM)的在线3D实例分割框架。该框架利用2D视觉基础模型辅助实时3D场景理解,解决了高质量3D数据稀缺的难题,为机器人导航、操作等任务提供了高…

信创-人大金仓数据库创建

一. 官文 资源下载地址 https://download.kingbase.com.cn/xzzx/index.htm 下载安装文件 下载授权文件 产品文档地址:https://help.kingbase.com.cn/v8/index.html 二. 概念 2.1 体系结构 ‌ 实例结构 ‌:由数据库文件和 KingbaseES 实例组成。数据…

C++第三种异质集合 std::any方式实现

#include <type_traits> #include <any> #include <functional> #include <iomanip> #include <iostream> #include <typeindex> #include <typeinfo> #include <unordered_map> #include <vector> //any是编译期的异质…

Springboot实现使用断点续传优化同步导入Excel

springboot实现使用断点续传优化同步导入Excel 需求前言断点续传前端实现后端实现完结撒花&#xff0c;如有需要收藏的看官&#xff0c;顺便也用发财的小手点点赞哈&#xff0c;如有错漏&#xff0c;也欢迎各位在评论区评论&#xff01; 需求前言 在跨境电商系统中&#xff0c…

mysql 对json的处理?

MySQL从5.7版本开始支持JSON数据类型&#xff0c;并提供了多种函数来查询和处理JSON数据。以下是一些基本的操作和函数&#xff1a; 创建包含JSON列的表&#xff1a; 可以直接在表定义中指定某列为JSON类型。 CREATE TABLE my_table (id INT NOT NULL AUTO_INCREMENT,data JSON…

Nexus L2 L3基本配置

接口基本配置 N7K上所有端口默认处于shutdown状态; N5K上所有端口默认处于no shutdown状态(所有端口都是switchport) 默认所有接口都是三层route模式, 只有当线卡不支持三层的时候, 接口才会处于二层switchport模式 show run all | in “system default” 创建SVI口需要提前打…

HCIA-AI人工智能笔记3:数据预处理

统讲解数据预处理的核心技术体系&#xff0c;通过Python/Pandas与华为MindSpore双视角代码演示&#xff0c;结合特征工程优化实验&#xff0c;深入解析数据清洗、标准化、增强等关键环节。 一、数据预处理技术全景图 graph TD A[原始数据] --> B{数据清洗} B --> B1[缺…

G-Star 校园开发者计划·黑科大|开源第一课之 Git 入门

万事开源先修 Git。Git 是当下主流的分布式版本控制工具&#xff0c;在软件开发、文档管理等方面用处极大。它能自动记录文件改动&#xff0c;简化合并流程&#xff0c;还特别适合多人协作开发。学会 Git&#xff0c;就相当于掌握了一把通往开源世界的钥匙&#xff0c;以后参与…

MySQL错误 “duplicate entry ‘1‘ for key ‘PRIMARY‘“ 解决方案

文章目录 1. 错误原因分析2. 快速解决方法场景1:手动插入重复值场景2:自增主键冲突场景3:批量插入冲突3. 长期预防策略4. 高级排查技巧该错误通常由主键冲突引起,表示尝试插入或更新的主键值已存在于表中。以下是分步排查和解决方法: 1. 错误原因分析 主键唯一性约束:表…

WEB攻防-PHP反序列化-字符串逃逸

目录 前置知识 字符串逃逸-减少 字符串逃逸-增多 前置知识 1.PHP 在反序列化时&#xff0c;语法是以 ; 作为字段的分隔&#xff0c;以 } 作为结尾&#xff0c;在结束符}之后的任何内容不会影响反序列化的后的结果 class people{ public $namelili; public $age20; } var_du…

把生产队的大模型Grok 3 beta用来实现字帖打磨

第一个版本&#xff0c;就是简单的田字格&#xff0c;Grok 3 beta 思考了15s就得到了html前端代码&#xff0c;javascript; 然而还不完美&#xff1b; 第二个版本&#xff0c;进一步&#xff0c;通过pinyin项目给汉字加上注音&#xff0c;米字格和四线格&#xff1b;&#xff…

windows+ragflow+deepseek实战之一excel表查询

ragflows平台部署参考文章 Win10系统Docker+DeepSeek+ragflow搭建本地知识库 ragflow通过python实现参考这篇文章 ragflow通过python实现 文章目录 背景效果1、准备数据2、创建知识库3、上传数据并解析4、新建聊天助理5、测试会话背景 前面已经基于Win10系统Docker+DeepSeek+…