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

小程序API —— 53 本地存储

小程序本地存储是指在小程序中使用 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.dtcms.com/a/76118.html

相关文章:

  • 1~2 课程简介+ESP32-IDF环境搭建(虚拟机Linux环境下)
  • 大语言模型的压缩技术
  • AI如何在财务工作中提升效率的一些看法
  • JavaScript日期区间计算:精准解析年月日差异
  • EG8200多协议图形化编程边缘计算网关
  • Python----计算机视觉处理(Opencv:图像镜像旋转)
  • 大数据分析方法(65页PPT)
  • cmake 之 check_language()
  • AIP-182 外部软件依赖
  • Linux 网络基础设置
  • jenkins pipline 自动化测试
  • 案例驱动的 IT 团队管理:创新与突破之路:第三章 项目攻坚:从流程优化到敏捷破局-3.1.2需求分级与资源调配策略
  • 海康SDK协议在智联视频超融合平台中的接入方法
  • springboot+自定义注解+AOP实现权限控制(一)
  • EasyRTC嵌入式音视频通话SDK:如何解决跨平台(Linix、Windows、ARM、物联网)、跨设备(Android、ios等)的兼容性难题?
  • 前端Vue3图像编辑功能(并生成mask图)
  • 我在哪,要去哪
  • Zbrush插件安装
  • Android Studio最后一个绑定JDK8的版本,但是官方下载是最新的,怎么下载Android Studio历史版本包,这篇文章帮你解决。
  • Java进阶核心技术解析:多线程、集合框架与反射深度实战
  • 车载网络测试【E2E-AUTOSAR E2E Profile 1】
  • 4.3--入门知识扫盲,IPv4的头部报文解析,数据报分片,地址分类(包你看一遍全部记住)
  • Docker搭建MySQL主从服务器
  • 电商无人直播防封指南:三要素构建智能防护(场景切换/实时互动/自动审核)
  • JavaScript日期区间计算
  • Docker换源加速(更换镜像源)详细教程(2025.3最新可用镜像,全网最详细)
  • Using SAP S4hana An Introduction for Business Users
  • 【机器学习-回归算法】
  • 宝石PDF,全新 PC 版本,全部免费
  • 本专栏开栏通知相关申明