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

前言

uniapp项目中,每个tabbar页面来回点时候,不会触发页面更新。但是有时页面上有数据发生改变需要更新模版时,就得能及时的通知到页面。如果在onshow生命周期里每次都调用异步请求更新数据,有些不合理,况且页面有时不需要更新。

经过思考,我们可以定义一个全局变量,根据全局变量的值来看是否需要更新数据。

开始

细化需求举例:下图是我的聊天记录列表。

当我有新的聊天时,点击"对话"tabbar需要更新此列表。

当无新聊天时,点击此"对话"tabbar不做任何动作。

首先定义全局变量:

根目录/src/utils/globleState.js:

javascript 复制代码
import { ref,reactive } from "vue"

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

在聊天记录页面这样用:

src/pages/chatList/chatList.vue

javascript 复制代码
<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

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

后记

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

相关推荐
假客套3 小时前
2025 后端自学UNIAPP【项目实战:旅游项目】1、创建项目框架
uni-app·旅游
济南壹软网络科技-专注源码开发数十年!3 小时前
盲盒源码_盲盒系统_盲盒定制开发 盲盒搭建前端教程
开发语言·前端·uni-app·php
象骑士Hack5 小时前
Uni-app小程序 hello world示例
小程序·uni-app
ʚʕ̯•͡˔•̯᷅ʔɞ LeeKuma11 小时前
Vue3携手Echarts,打造炫酷数据可视化大屏
信息可视化·echarts·vue3
BOB-wangbaohai11 小时前
Flowable7.x学习笔记(二十)查看流程办理进度图
流程图·vue3·springboot3.x·flowable7.x
爱笑的眼睛1121 小时前
uniapp 云开发全集 云数据库
javascript·数据库·oracle·uni-app
青茶3601 天前
uniapp开发微信小程序时如何进行分包(新手图文)
微信小程序·小程序·uni-app
lh_12542 天前
Uni-app 组件使用
前端·javascript·uni-app
Kx…………2 天前
Day3:设置页面全局渐变线性渐变背景色uniapp壁纸实战
前端·学习·uni-app·实战·项目
lh_12542 天前
前端 uni-app 初步使用指南
前端·arcgis·uni-app