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

uniapp vue3项目定义全局变量,切换底部babar时根据条件刷新页面

前言

uniapp项目中,每个tabbar页面来回点时候,不会触发页面更新。但是有时页面上有数据发生改变需要更新模版时,就得能及时的通知到页面。如果在onshow生命周期里每次都调用异步请求更新数据,有些不合理,况且页面有时不需要更新。
经过思考,我们可以定义一个全局变量,根据全局变量的值来看是否需要更新数据。

开始

细化需求举例:下图是我的聊天记录列表。
当我有新的聊天时,点击“对话”tabbar需要更新此列表。
当无新聊天时,点击此“对话”tabbar不做任何动作。
在这里插入图片描述

首先定义全局变量:
根目录/src/utils/globleState.js:

import { ref,reactive } from "vue"

let gloableState = reactive({
	chatListIsRefresh:false,  // 是否需要刷新聊天记录列表
	collectListIsRefresh:false
})
export function useGloableState(){
	return gloableState
}

在聊天记录页面这样用:
src/pages/chatList/chatList.vue

<script setup>
	import {useGloableState} from '@/utils/gloableState.js'
	let gloableState = useGloableState()
	getChatList(){
		let res = await ... // 异步请求取最新的聊天记录列表
		gloableState.chatListIsRefresh = false; // 更新全局变量,表示聊天列表已是最新
	}
	onShow(() => {
		if(gloableState.chatListIsRefresh){ // 如果检测到需要更新聊天记录列表才重新请求数据
			getChatList() // 重新请求数据
		}
	});
</script>

在聊天页面,如果有新聊天,去更新全局变量为true,表示有新聊天,需要刷新聊天记录列表:
src/pages/chat/chat.vue

<script setup>
	import {useGloableState} from '@/utils/gloableState.js'
	let gloableState = useGloableState()
	chat(){
		... // 此处为发送聊天逻辑
		gloableState.chatListIsRefresh = true; // 更新全局变量,表示聊天列表需要更新
	}
</script>

后记

在此记录问题解决方法,也给需要的朋友们一个思路。有问题可以留言我们一起讨论。

http://www.dtcms.com/a/75293.html

相关文章:

  • Spring中Bean的自动装配
  • 电脑型号与尺寸
  • 大数据学习拓展——Minio安装与使用
  • Unity Shader - UI Sprite Shader之简单抠图效果
  • ollama docker设置模型常驻显存
  • 流量分析实践
  • 【Python 算法零基础 1.线性枚举】
  • 使用htool工具导出和导入Excel表
  • springboot学习(自定义starter)
  • GO语言的GC(垃圾回收)原理
  • 探索可变参数提升不变学习以增强分布外泛化能力
  • Android ARouter的详细使用指南
  • 京东云DeepSeek-R1模型一键部署教程,基于智算GCS【成本2元】
  • Ansible 如何使用 Playbook 批量部署应用?
  • Unity WebGL项目访问时自动全屏
  • vue 加密解密
  • 基于PMU的14节点、30节点电力系统状态估计MATLAB程序
  • AndroidStudio下载安装,环境部署以及常见问题解决教程(亲测)
  • 游戏立项时期随笔记录(1)
  • MySql数据库(表数据的增、删、改操作)8
  • mysql5.x和mysql8.x查看和设置隔离级别
  • VSCode C/C++ 环境搭建指南
  • JS逆向案例-通达OA Office Anywhere 2019 的前端密码加密逆向分析
  • SiC/GaN器件测试新选择:MHO5000如何破解高频开关噪声难题?
  • 【MySQL】第十八弹---数据库管理基础:视图操作与用户权限管理指南
  • 2025“钉耙编程”中国大学生算法设计春季联赛(2)题解
  • 第二章:GPT的发展史
  • 2025最新版Windows通过GoLand远程连接Linux构建Go项目保姆级教学
  • 自然语言处理|让AI更聪明:如何用百科知识喂饱语言模型
  • Android Studio如何设置中文