小程序API —— 53 本地存储

ops/2025/3/20 0:16:22/

小程序本地存储是指在小程序中使用 API 将数据存储在用户的设备上,以便小程序在运行时和下次启动时快速地读取这些数据;

小程序本地存储的 API 可以分为两类,每一类可以分为四种:

  • 同步 API:
    • 存储:wx.setStorageSync()
    • 获取:wx.getStorageSync()
    • 删除:wx.removeStorageSync()
    • 清空:wx.clearStorageSync()
  • 异步 API:
    • 存储:wx.setStorage()
    • 获取:wx.getStorage()
    • 删除:wx.removeStorage()
    • 清空:wx.clearStorage()

注意,在微信小程序中,对象类型的数据,可以直接进行存储获取,无需使用 JSON.stringify()、JSON.parse() 转换;

下面我们打开微信开发者工具来演示如何使用这八个 API:

  • 首先演示一下同步 API 用法

    • 在 pages/cate/cate.wxml 文件中添加以下代码,用于添加对应的按钮:

      <button size="mini" plain type="warn" bind:tap="setStorage">存储</button>
      <button size="mini" plain type="primary" bind:tap="getStorage">获取</button>
      <button size="mini" plain type="warn" bind:tap="removeStorage">删除</button>
      <button size="mini" plain type="primary" bind:tap="clearStorage">清空</button>
      
    • 在 pages/cate/cate.scss 文件中添加 button 的样式代码,如下:

      button {margin: 34rpx;
      }
      
    • 我们首先演示一下 同步存储 wx.setStorageSync 的功能,在 pages/cate/cate.js 文件中添加下面代码:

      Page({// 将数据存储到本地setStorage(){wx.setStorageSync('num', 1);// 存储对象类型,不需要使用 JSON.stringify 和 JSON.parse 转换wx.setStorageSync('obj', {name: 'tom', age: 10})}
      }
    • 接着点击保存按钮,在右下角选择【storage】,可以看到保存到本地的数据,如下:

      在这里插入图片描述

    • 接着在 pages/cate/cate.js 文件中添加同步获取本地数据的代码,如下:

      Page({// 将数据存储到本地getStorage(){const num = wx.getStorageSync('num');const obj = wx.getStorageSync('obj');console.log(num);console.log(obj);}
      }
    • 点击获取按钮,可以在 console 区域中看到打印的信息,如下:

      在这里插入图片描述

    • 接着在 pages/cate/cate.js 文件中添加同步删除本地数据的代码,如下:

      Page({// 删除本地存储的数据removeStorage(){wx.removeStorageSync('num');}
      }
    • 当点击删除按钮时,可以看到 storage 中存储的 num 数据被清空,如下:

      在这里插入图片描述

    • 接着在 pages/cate/cate.js 文件中添加同步清空本地数据的代码,如下:

      Page({// 清空本地存储的全部数据clearStorage(){wx.clearStorageSync();}
      }
    • 当点击清空按钮时,可以看到 storage 区域中保存的两个数据都被清空了,如下:

      在这里插入图片描述

  • 接着演示一下异步 API 用法

    • 在 pages/cate/cate.wxml 文件中添加以下代码,用于添加对应的按钮:

      <button size="mini" plain type="warn" bind:tap="setStorage">存储</button>
      <button size="mini" plain type="primary" bind:tap="getStorage">获取</button>
      <button size="mini" plain type="warn" bind:tap="removeStorage">删除</button>
      <button size="mini" plain type="primary" bind:tap="clearStorage">清空</button>
      
    • 在 pages/cate/cate.scss 文件中添加 button 的样式代码,如下:

      button {margin: 34rpx;
      }
      
    • 我们首先演示一下 异步存储 wx.setStorage 的功能,在 pages/cate/cate.js 文件中添加下面代码:

      Page({// 将数据存储到本地setStorage(){wx.setStorage({key: 'num', data: 1});// 存储对象类型,不需要使用 JSON.stringify 和 JSON.parse 转换wx.setStorage({key: 'obj', data: {name: 'tom', age: 10}});}
      }
    • 接着点击保存按钮,在右下角选择【storage】,可以看到保存到本地的数据,如下:

      在这里插入图片描述

    • 接着在 pages/cate/cate.js 文件中添加异步获取本地数据的代码,如下:

      Page({// 获取本地存储的数据async getStorage(){const {data} = await wx.getStorage({key:'obj'});console.log(data);}
      }
    • 点击获取按钮,可以在 console 区域中看到打印的信息,如下:

      在这里插入图片描述

    • 接着在 pages/cate/cate.js 文件中添加异步删除本地数据的代码,如下:

      Page({// 删除本地存储的数据removeStorage(){wx.removeStorage({key:'num'});}
      }
    • 当点击删除按钮时,可以看到 storage 中存储的 num 数据被清空,如下:

      在这里插入图片描述

    • 接着在 pages/cate/cate.js 文件中添加异步清空本地数据的代码,如下:

      Page({// 清空本地存储的全部数据clearStorage(){wx.clearStorage();}
      }
    • 当点击清空按钮时,可以看到 storage 区域中保存的两个数据都被清空了,如下:

      在这里插入图片描述

参考视频:尚硅谷微信小程序开发教程


http://www.ppmy.cn/ops/167144.html

相关文章

从bootloader跳到APP需要几步?

从bootloader跳到APP需要几步&#xff1f; 对于bootloader跳转到APP具体流程&#xff0c;我们用下面一个例子去讲解。首先将 bootloader 程序和 app 程序的大小都是 2K &#xff0c;bootloader 从 0x08000000 到 0x080007FF , app 程序从 0x08000800 到 0x08000FFF 。   接下…

API 返回的PDF是一串字符,如何转换为PDF文档

当API返回的PDF是以一串字符的形式&#xff08;通常是Base64编码的字符串&#xff09;&#xff0c;你可以将其解码为二进制数据&#xff0c;然后保存为PDF文件。以下是一个简单的Python示例&#xff0c;展示如何将Base64编码的PDF字符串转换为PDF文档&#xff1a; import base…

基于Python+Flask+MySQL+HTML的爬取豆瓣电影top-250数据并进行可视化的数据可视化平台

FlaskMySQLHTML 项目采用前后端分离技术&#xff0c;包含完整的前端&#xff0c;以flask作为后端 Pyecharts、jieba进行前端图表展示 通过MySQL收集格列数据 通过Pyecharts制作数据图表 这是博主b站发布的详细讲解&#xff0c;感兴趣的可以去观看&#xff1a;【Python爬虫可…

WPF CommunityToolkit.MVVM库的简单使用

CommunityToolkit.MVVM 是 .NET 社区工具包中的一部分&#xff0c;它为实现 MVVM&#xff08;Model-View-ViewModel&#xff09;模式提供了一系列实用的特性和工具&#xff0c;能帮助开发者更高效地构建 WPF、UWP、MAUI 等应用程序。以下是关于它的详细使用介绍&#xff1a; 1…

C++输入输出流第一弹:标准输入输出流 详解(带测试代码)

目录 C输入输出流 流的四种状态&#xff08;重点&#xff09; 标准输入输出流 标准输入流 逗号表达式 1. 逗号表达式的基本规则 示例 2. 图片中的代码分析 关键点解析 3. 常见误区 误区 1&#xff1a;逗号表达式等同于逻辑与 && 误区 2&#xff1a;忽略输入…

命令行参数和环境变量【Linux操作系统】

文章目录 命令行参数命令行参数有什么用呢&#xff1f;main函数的参数是谁传递的? 环境变量环境变量的作用简单介绍一下常见的环境变量环境变量HOME&#xff1a;环境变量PWD环境变量USER环境变量OLDPWD环境变量相关指令和函数 本地变量环境变量于本地变量的区别环境变量为什么…

保姆级离线TiDB V8+解释

以前学习的时候还是3版本&#xff0c;如今已经是8版本了 https://cn.pingcap.com/product-community/?_gl1ujh2l9_gcl_auMTI3MTI3NTM3NC4xNzM5MjU3ODE2_gaMTYwNzE2NTI4OC4xNzMzOTA1MjUz_ga_3JVXJ41175MTc0MTk1NTc1OC4xMS4xLjE3NDE5NTU3NjIuNTYuMC41NDk4MTMxNTM._ga_CPG2VW1Y4…

SQL Server表数据变更捕获的5种方法及实战对比

在数据驱动的业务场景中&#xff0c;准确捕获SQL Server表数据变更是数据审计、业务分析、系统集成等场景的必备能力。本文深入解析五种主流变更捕获方案&#xff0c;并提供企业级方案选型指南&#xff0c;帮助开发者构建高效可靠的变更追踪体系。 一、变更捕获核心技术原理 …