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

Uniapp 页面返回不刷新?两种方法防止 onShow 触发多次请求!

目录

  • 前言
  • 1. 变量(不生效)
  • 2. 延迟(生效)

前言

🤟 找工作,来万码优才:👉 #小程序://万码优才/r6rqmzDaXpYkJZF

在 Uniapp 中,使用 onShow() 钩子来监听页面显示,从而在页面返回时刷新数据

例如:

onShow() {
  this.getLastSubmission(); // 重新请求数据
}

但这样会导致 初次进入页面 时 onShow() 也会执行一次 getLastSubmission(),而 onLoad() 也会调用它,导致 多次请求,带来性能问题和不必要的 API 调用

初次进入时 只调用一次 getLastSubmission(),返回页面时也只会调用 getLastSubmission() 以刷新数据
避免 onShow 和 onLoad 同时触发 getLastSubmission()

在 Uniapp 的页面生命周期中:

  • onLoad() 仅在页面首次创建时调用一次。
  • onShow() 每次页面 显示 时都会触发,包括:
    首次进入页面
    从其他页面返回

如果 onLoad() 和 onShow() 都调用 getLastSubmission(),那么:
初次进入:onLoad() 调用 getLastSubmission(),然后 onShow() 立即执行,导致 请求了两次
返回页面:onShow() 再次调用 getLastSubmission(),符合预期

需要解决 初次进入时调用两次的问题

在这里插入图片描述

1. 变量(不生效)

定义 firstLoad 变量,初次进入页面时设为 true。
onLoad() 执行 getLastSubmission(),但 onShow() 第一次不执行。
onShow() 仅在 firstLoad = false 后执行,避免初次进入时的重复调用

export default {
	data() {
		return {
			lastSubmission: null, 
			firstLoad: true // 标记是否是第一次进入
		};
	},
	onLoad() {
		this.getLastSubmission(); // 初次加载时调用
	},
	onShow() {
		if (!this.firstLoad) {
			this.getLastSubmission(); // 仅在返回时调用
		} else {
			this.firstLoad = false; // 标记为已加载,后续 onShow 可执行
		}
	},
	methods: {
		async getLastSubmission() {
			try {
				const res = await getSelf();
				if (res?.data) {
					this.lastSubmission = res.data;
				} else {
					this.lastSubmission = null;
				}
			} catch (error) {
				this.lastSubmission = null;
			}
		}
	}
};

2. 延迟(生效)

核心思路:

在 onLoad() 先调用 getLastSubmission(),但不立即设置 loaded = true.通过 setTimeout() 稍微延迟 loaded,确保 onShow() 触发时不会误调用

export default {
	data() {
		return {
			lastSubmission: null, 
			loaded: false // 标记是否已经加载过
		};
	},
	onLoad() {
		this.getLastSubmission().then(() => {
			setTimeout(() => {
				this.loaded = true; // 延迟标记 loaded,防止 onShow 立即执行
			}, 100); 
		});
	},
	onShow() {
		if (this.loaded) {
			this.getLastSubmission(); 
		}
	},
	methods: {
		async getLastSubmission() {
			try {
				const res = await getSelf();
				if (res?.data) {
					this.lastSubmission = res.data;
				} else {
					this.lastSubmission = null;
				}
			} catch (error) {
				this.lastSubmission = null;
			}
		}
	}
};

初次进入:
onLoad() 调用 getLastSubmission(),但 loaded 需要 100ms 才变 true。onShow() 立即触发,但 loaded = false,不会调用 getLastSubmission()

返回页面:
onShow() 触发 getLastSubmission(),刷新数据


http://www.kler.cn/a/574317.html

相关文章:

  • 极狐GitLab 正式发布安全版本17.9.1、17.8.4、17.7.6
  • 大模型——使用 Embedding 模型和向量数据库的 Spring AI RAG
  • sqlite3 c++ client选择; c++环境搭建 : abseil-cpp | fnc12/sqlite_orm
  • 【Day9】make/makeFile如何让项目构建自动化起飞
  • go语言设计模式-适配器模式
  • RV1126采集VI视频数据流
  • 自动任务:安卓与鸿蒙上的高效自动化助手
  • Mac 基于 Ollama 安装 DeepSeek-R1(蒸馏版本)、AnythingLLM 及使用体验
  • JavaEE Servlet02
  • docker目录挂载与卷映射的区别
  • 洛谷————B2056 求整数的和与均值
  • 【网络】实现电脑与笔记本电脑之间的直接网络连接
  • 双向选择排序算法
  • 文档处理控件Aspose.Total教程:使用 C# 将 Obsidian Markdown 转换为 OneNote
  • 无线可视挖耳勺适合老年人吗?无线可视挖耳勺操作简单又安全
  • WPS AI+office-ai的安装、使用
  • 3.6V-30V宽压输入降压同步IC内置MOS,电流4A/5A/6A,可以满足汽车应急电源,BMS电池,电池组USB口输出等储能应用
  • TTP/HTTPS、TCP/IP 协议、RPC、Socket 通信机制
  • RxJS与Redux革命性协同:打造高效、解耦的前端状态管理方案
  • 【摸鱼指南】--- VSCode 使用 Thief-Book 隐形阅读模式配置教程 程序员必备插件