Vue 缓存之坑,变量赋值方式和响应式数据

复制代码
const { IsSuperAdmin } = useUserStore().userInfo;

  /**
   * 获取后台动态路由数据,解析并注册到全局路由
   *
   * @returns Promise<RouteRecordRaw[]> 解析后的动态路由列表
   */
  function generateRoutes() {
    return new Promise<RouteRecordRaw[]>((resolve, reject) => {
      console.log("userInfo", useUserStore().userInfo);
      console.log("IsSuperAdmin", IsSuperAdmin);
      .....
  }

这个问题涉及到 JavaScript 的变量赋值方式响应式数据的特性。让我详细解释一下:

问题原因

复制代码
const { IsSuperAdmin } = useUserStore().userInfo;

这行代码使用了解构赋值 ,它创建了一个新的变量 IsSuperAdmin,这个变量是原始值的拷贝,而不是引用。

具体解释

1、解构赋值创建的是拷贝

  • const { IsSuperAdmin } = useUserStore().userInfo; 相当于:

  • const IsSuperAdmin = useUserStore().userInfo.IsSuperAdmin;

  • 这是一个值拷贝,不是引用

2、响应式数据需要特殊处理

  • 如果 useUserStore().userInfo 是响应式对象(如 Vue 的 reactive 或 Pinia 的 store)

  • 直接解构会失去响应性,得到的是当前时刻的静态值

3、console.log 显示的是不同来源

  • useUserStore().userInfo.IsSuperAdmin → 直接从 store 读取,获取最新值

  • IsSuperAdmin → 解构时拷贝的旧值,不会自动更新

解决方案

方案1:直接访问 store(推荐)

复制代码
function generateRoutes() {
  return new Promise<RouteRecordRaw[]>((resolve, reject) => {
    const userStore = useUserStore();
    console.log("userInfo", userStore.userInfo.IsSuperAdmin); // 最新值
    console.log("IsSuperAdmin", userStore.userInfo.IsSuperAdmin); // 最新值
    // ...
  });
}

方案2:使用计算属性(如果需要响应式)

复制代码
import { computed } from 'vue';

const IsSuperAdmin = computed(() => useUserStore().userInfo.IsSuperAdmin);

function generateRoutes() {
  return new Promise<RouteRecordRaw[]>((resolve, reject) => {
    console.log("userInfo", useUserStore().userInfo.IsSuperAdmin);
    console.log("IsSuperAdmin", IsSuperAdmin.value); // 使用 .value
    // ...
  });
}

方案3:使用 toRefs 保持响应性

复制代码
import { toRefs } from 'vue';

const { IsSuperAdmin } = toRefs(useUserStore().userInfo);

function generateRoutes() {
  return new Promise<RouteRecordRaw[]>((resolve, reject) => {
    console.log("userInfo", useUserStore().userInfo.IsSuperAdmin);
    console.log("IsSuperAdmin", IsSuperAdmin.value); // 使用 .value
    // ...
  });
}

最佳实践

避免在函数外部解构响应式数据,而是在需要的时候直接从 store 中读取:

复制代码
function generateRoutes() {
  return new Promise<RouteRecordRaw[]>((resolve, reject) => {
    const userStore = useUserStore();
    // 始终使用 userStore.userInfo.IsSuperAdmin 来获取最新值
    console.log("IsSuperAdmin status:", userStore.userInfo.IsSuperAdmin);
    // ...
  });
}

这样可以确保你总是获取到最新的数据,而不是过时的拷贝值。

文章转载自: VipSoft

原文链接: https://www.cnblogs.com/vipsoft/p/19058216

体验地址: http://www.jnpfsoft.com/?from=001YH

相关推荐
SuperEugene2 分钟前
Vue3 + Element Plus 表格实战:批量操作、行内编辑、跨页选中逻辑统一|表单与表格规范篇
开发语言·前端·javascript
1104.北光c°10 分钟前
深入浅出 Elasticsearch:从搜索框到精准排序的架构实战
java·开发语言·elasticsearch·缓存·架构·全文检索·es
极梦网络无忧26 分钟前
基于 Vite + Vue3 的组件自动注册功能
前端·javascript·vue.js
FakeOccupational32 分钟前
【电路笔记 STM32】Cortex-M7 内核上的数据缓存结构图 + MPU内存保护单元 + Cache基本操作 + Cache&DMA 时序图
笔记·stm32·缓存
AMoon丶37 分钟前
Golang--内存管理
开发语言·后端·算法·缓存·golang·os
Predestination王瀞潞39 分钟前
5.4.3 通信->WWW万维网内容访问标准(W3C):WWW(World Wide Web) 协议架构(分层)
前端·网络·网络协议·架构·www
爱学习的程序媛1 小时前
【Web前端】优化Core Web Vitals提升用户体验
前端·ui·web·ux·用户体验
zabr1 小时前
花了 100+ 篇笔记,我整理出 了一套 AI Agent 工程完全指南
前端·后端·agent
软弹1 小时前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js
YaHuiLiang1 小时前
Ai Coding浪潮下的前端:“AI在左,裁员在右”
前端