微信小程序在使用页面栈保存页面信息时,如何避免数据丢失?

news2025/1/17 8:54:17

微信小程序在使用页面栈保存页面信息时避免数据丢失的方法:

一、使用全局变量存储关键数据

  1. 定义一个全局变量,例如在 app.js 中,用于存储页面的重要信息。
  2. 在页面的 onHideonUnload 生命周期中,将需要保存的数据存储到该全局变量。
  3. 在页面的 onShow 生命周期中,从全局变量中读取数据并恢复页面状态。

二、使用本地存储(Local Storage)

  1. 在页面的 onHideonUnload 生命周期中,使用 wx.setStorageSyncwx.setStorage 将重要数据存储到本地存储。
  2. 在页面的 onShow 生命周期中,使用 wx.getStorageSyncwx.getStorage 从本地存储中读取数据并恢复页面状态。

三、使用页面栈的 data 属性进行临时存储

  1. 在页面的 onHideonUnload 生命周期中,将重要数据存储到页面栈的 data 属性中。
  2. 在页面的 onShow 生命周期中,从页面栈的 data 属性中读取数据并恢复页面状态。

以下是具体的实现示例:

一、使用全局变量存储关键数据

app.js

App({
  globalData: {
    pageData: {}
  }
});

页面的 js 文件

const app = getApp();

Page({
  data: {
    list: [],
    inputValue: ''
  },

  onLoad: function() {
    // 模拟生成一些列表数据
    let tempList = [];
    for (let i = 0; i < 100; i++) {
      tempList.push(`Item ${i}`);
    }
    this.setData({
      list: tempList
    });
  },

  onHide: function() {
    // 存储数据到全局变量
    let pages = getCurrentPages();
    let currentPage = pages[pages.length - 1];
    app.globalData.pageData[currentPage.route] = {
      inputValue: this.data.inputValue,
      list: this.data.list
    };
  },

  onShow: function() {
    // 从全局变量中读取数据
    let pageData = app.globalData.pageData[this.route];
    if (pageData) {
      this.setData({
        inputValue: pageData.inputValue,
        list: pageData.list
      });
    }
  },

  onInput: function(event) {
    this.setData({
      inputValue: event.detail.value
    });
  }
});

代码解释

  • app.js
    • 定义了一个 globalData 对象,其中 pageData 用于存储各个页面的数据。
  • 页面的 js 文件
    • onLoad:模拟生成列表数据并更新到 data 中。
    • onHide:将当前页面的输入框值 inputValue 和列表数据 list 存储到 app.js 的全局变量中,使用 currentPage.route 作为存储的键,确保每个页面的数据存储在不同的位置。
    • onShow:从 app.js 的全局变量中根据当前页面的路由读取数据,并更新到当前页面的 data 中。
    • onInput:更新输入框的值到 data 中。

二、使用本地存储(Local Storage)

页面的 js 文件

Page({
  data: {
    list: [],
    inputValue: ''
  },

  onLoad: function() {
    // 模拟生成一些列表数据
    let tempList = [];
    for (let i = 0; i < 100; i++) {
      tempList.push(`Item ${i}`);
    }
    this.setData({
      list: tempList
    });
  },

  onHide: function() {
    // 存储数据到本地存储
    wx.setStorageSync(this.route, {
      inputValue: this.data.inputValue,
      list: this.data.list
    });
  },

  onShow: function() {
    // 从本地存储中读取数据
    let pageData = wx.getStorageSync(this.route);
    if (pageData) {
      this.setData({
        inputValue: pageData.inputValue,
        list: pageData.list
      });
    }
  },

  onInput: function(event) {
    this.setData({
      inputValue: event.detail.value
    });
  }
});

代码解释

  • onLoad:模拟生成列表数据并更新到 data 中。
  • onHide:使用 wx.setStorageSync 将当前页面的输入框值 inputValue 和列表数据 list 存储到本地存储,以当前页面的路由作为存储的键。
  • onShow:使用 wx.getStorageSync 从本地存储中根据当前页面的路由读取数据,并更新到当前页面的 data 中。
  • onInput:更新输入框的值到 data 中。

三、使用页面栈的 data 属性进行临时存储

页面的 js 文件

Page({
  data: {
    list: [],
    inputValue: ''
  },

  onLoad: function() {
    // 模拟生成一些列表数据
    let tempList = [];
    for (let i = 0; i < 100; i++) {
      tempList.push(`Item ${i}`);
    }
    this.setData({
      list: tempList
    });
  },

  onHide: function() {
    // 存储数据到页面栈的 data 属性
    let pages = getCurrentPages();
    let currentPage = pages[pages.length - 1];
    currentPage.data.savedData = {
      inputValue: this.data.inputValue,
      list: this.data.list
    };
  },

  onShow: function() {
    // 从页面栈的 data 属性中读取数据
    let pages = getCurrentPages();
    let currentPage = pages[pages.length - 1];
    let savedData = currentPage.data.savedData;
    if (savedData) {
      this.setData({
        inputValue: savedData.inputValue,
        list: savedData.list
      });
    }
  },

  onInput: function(event) {
    this.setData({
      inputValue: event.detail.value
    });
  }
});

代码解释

  • onLoad:模拟生成列表数据并更新到 data 中。
  • onHide:将当前页面的输入框值 inputValue 和列表数据 list 存储到页面栈当前页的 data 属性中的 savedData 对象中。
  • onShow:从页面栈当前页的 data 属性中读取 savedData,并更新到当前页面的 data 中。
  • onInput:更新输入框的值到 data 中。

注意事项

  • 全局变量方法:
    • 适合存储一些全局通用的数据,但如果存储的数据过多,可能会占用较多内存,并且在小程序关闭后数据会丢失。
    • 对于一些轻量级的数据和状态,这种方式较为方便。
  • 本地存储方法:
    • 数据存储在本地,即使小程序关闭后也能保存,但存储的数据大小有限制(一般不超过 10MB)。
    • 适合存储需要长期保存的数据,但读取和写入速度相对较慢。
  • 页面栈 data 属性方法:
    • 适合临时存储,仅在页面栈存在时有效,小程序关闭后会丢失数据。
    • 适合存储页面切换时的临时状态数据。

你可以根据不同的需求选择合适的存储方式,以确保在使用页面栈保存页面信息时避免数据丢失。同时,在存储和读取数据时要注意数据的结构和键的设置,确保数据的一致性和准确性。

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

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

相关文章

得物App利用技术赋能,打造潮流消费“新玩法”

如今&#xff0c;技术的力量正在以前所未有的方式重塑着我们的消费体验。从线上购物到虚拟现实&#xff0c;技术的角色越来越重要&#xff0c;它不仅是推动商业发展的引擎&#xff0c;更是满足年轻消费者多元化、个性化需求的关键。得物App作为一个年轻人喜爱的潮流消费平台&am…

语义检索效果差?深度学习rerank VS 统计rerank选哪个

前段时间我开发了一个用白话文搜索语义相近的古诗词的应用&#xff08;详见&#xff1a;《朋友圈装腔指南&#xff1a;如何用向量数据库把大白话变成古诗词》&#xff09;&#xff0c;但是有时候搜索结果却不让人满意&#xff0c;排名靠前的结果和查询的语义没啥关系&#xff0…

数仓建模(三)建模三步走:需求分析、模型设计与数据加载

本文包含&#xff1a; 数据仓库的背景与重要性数据仓库建模的核心目标本文结构概览&#xff1a;需求分析、模型设计与数据加载 目录 第一部分&#xff1a;需求分析 1.1 需求分析的定义与目标 1.2 需求分析的步骤 1.2.1 业务需求收集 1.2.2 技术需求分析 1.2.3 成果输出…

【机器学习】制造业转型:机器学习如何推动工业 4.0 的深度发展

我的个人主页 我的领域&#xff1a;人工智能篇&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;&#x1f44d;点赞 收藏❤ 引言 在当今科技飞速发展的时代&#xff0c;制造业正经历着前所未有的变革&#xff0c;工业4.0的浪潮席卷而来。工业4.0旨在通过将…

MPLS原理及配置

赶时间可以只看实验部分 由来&#xff1a;90年代中期&#xff0c;互联网流量的快速增长。传统IP报文依赖路由器查询路由表转发&#xff0c;但由于硬件技术存在限制导致转发性能低&#xff0c;查表转发成为了网络数据转发的瓶颈。 因此&#xff0c;旨在提高路由器转发速度的MPL…

小程序如何引入腾讯位置服务

小程序如何引入腾讯位置服务 1.添加服务 登录 微信公众平台 注意&#xff1a;小程序要企业版的 第三方服务 -> 服务 -> 开发者资源 -> 开通腾讯位置服务 在设置 -> 第三方设置 中可以看到开通的服务&#xff0c;如果没有就在插件管理中添加插件 2.腾讯位置服务…

【spring mvc】文件上传、下载

文件上传&#xff0c;存储至本地目录中 一、代码1、工具类&#xff08;敏感后缀过滤&#xff09;2、文件上传&#xff0c;存储至本地3、文件下载 二、效果演示1、上传1.1、postMan 请求1.2、上传效果 2、下载2.1、下载效果 一、代码 1、工具类&#xff08;敏感后缀过滤&#x…

C语言预处理艺术:编译前的魔法之旅

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言正文一、预处理的作用与流程&#xf…

智汇云舟参编《城市轨道交通安全防范系统技术要求》国标正式发布

近日&#xff0c;根据国家标准化管理委员会官网&#xff0c;全国标准信息公共服务平台发布的公告&#xff0c;国家标准《城市轨道交通安全防范系统技术要求》&#xff08;GB/T 26718-2024&#xff09;已由全国城市轨道交通标准化技术委员会上报国家标准化管理委员会&#xff0c…

Linux(Centos7)安装Mysql/Redis/MinIO

安装Mysql 安装Redis 搜索Redis最先版本所在的在线安装yum库 查看以上两个组件是否是开机自启 安装MinIO 开源的对象存储服务&#xff0c;存储非结构化数据&#xff0c;兼容亚马逊S3协议。 minio --help #查询命令帮助minio --server --help #查询--server帮助minio serve…

Python从0到100(八十三):神经网络-使用残差网络RESNET识别手写数字

前言: 零基础学Python:Python从0到100最新最全教程。 想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Python爬虫、Web开发、 计算机视觉、机器学习、神经网络以及人工智能…

【漏洞分析】DDOS攻防分析

0x00 UDP攻击实例 2013年12月30日&#xff0c;网游界发生了一起“追杀”事件。事件的主角是PhantmL0rd&#xff08;这名字一看就是个玩家&#xff09;和黑客组织DERP Trolling。 PhantomL0rd&#xff0c;人称“鬼王”&#xff0c;本名James Varga&#xff0c;某专业游戏小组的…

【C#深度学习之路】如何使用C#实现Yolo8/11 Segment 全尺寸模型的训练和推理

【C#深度学习之路】如何使用C#实现Yolo8/11 Segment 全尺寸模型的训练和推理 项目背景项目实现推理过程训练过程 项目展望写在最后项目下载链接 本文为原创文章&#xff0c;若需要转载&#xff0c;请注明出处。 原文地址&#xff1a;https://blog.csdn.net/qq_30270773/article…

下载文件,浏览器阻止不安全下载

背景&#xff1a; 在项目开发中&#xff0c;遇到需要下载文件的情况&#xff0c;文件类型可能是图片、excell表、pdf、zip等文件类型&#xff0c;但浏览器会阻止不安全的下载链接。 效果展示&#xff1a; 下载文件的两种方式&#xff1a; 一、根据接口的相对url&#xff0c;拼…

如何在谷歌浏览器中设置自定义安全警告

随着网络环境的日益复杂&#xff0c;浏览器的安全问题也愈发引人关注。谷歌浏览器作为一款广泛使用的浏览器&#xff0c;其自定义安全警告功能为用户提供了更加个性化和安全的浏览体验。本文将详细介绍如何在谷歌浏览器中设置自定义安全警告&#xff0c;帮助用户更好地保护自己…

AI 编程工具—Cursor进阶使用 阅读开源项目

AI 编程工具—Cursor进阶使用 阅读开源项目 首先我们打开一个最近很火的项目browser-use ,直接从github 上克隆即可 索引整个代码库 这里我们使用@Codebase 这个选项会索引这个代码库,然后我们再选上这个项目的README.md 文件开始提问 @Codebase @README.md 这个项目是用…

细说STM32F407单片机窗口看门狗WWDG的原理及使用方法

目录 一、窗口看门狗的工作原理 1、递减计数器 2、窗口值和比较器 3、看门狗的启动 4、提前唤醒中断 二、窗口看门狗的HAL驱动程序 1、窗口看门狗初始化 2.窗口看门狗刷新 3.EWI中断及其处理 三、不开启EWI的WWDG示例 1、示例功能 2、项目设置 &#xff08;1&…

【Rust自学】12.6. 使用TDD(测试驱动开发)开发库功能

12.6.0. 写在正文之前 第12章要做一个实例的项目——一个命令行程序。这个程序是一个grep(Global Regular Expression Print)&#xff0c;是一个全局正则搜索和输出的工具。它的功能是在指定的文件中搜索出指定的文字。 这个项目分为这么几步&#xff1a; 接收命令行参数读取…

利用rsync备份全网服务器数据

一、项目描述 某公司里有一台Web服务器&#xff0c;里面的数据很重要&#xff0c;但是如果硬盘坏了数据就会丢失&#xff0c;现在领导要求把数据做备份&#xff0c;这样Web服务器数据丢失在可以进行恢复&#xff0c;要求如下&#xff1a; 1、备份要求 每天晚上00点整在Web服…

Go基础之环境搭建

文章目录 1 Go 1.1 简介 1.1.1 定义1.1.2 特点用途 1.2 环境配置 1.2.1 下载安装1.2.2 环境配置 1.2.2.1 添加环境变量1.2.2.2 各个环境变量理解 1.2.3 验证环境变量 1.3 包管理工具 Go Modules 1.3.1 开启使用1.3.2 添加依赖包1.3.3 配置国内包源 1.3.3.1 通过 go env 配置1.…