Vue3 双层ref问题不更新视图?其实是很基础的问题

🏠某知识点

有无其他知识 或 前置知识

这篇文章应该可以更好的理解这次问题->对象的引用和复制

📶简介

有无背景

在一次Echart的使用时候,我更新数据的时候图表没更新

❓为什么说这个?

情景复现

简述

我在关键的数据里有一个引用外界数据的过程,恰恰这个外界数据是ref定义的 然而就是这个数据导致我视图不更新了,但是打印的话还是正确更改了数据 所以问题就是dataArr身上了。先看代码🔽

代码

javascript 复制代码
const dataValue = ref<number[]>([])
  const dataArr = ref([
  {
    value: dataValue.value,// 引用上边定义的ref
  },
])
//echart配置 🔽
const update = (selectValue:string) => {
  chart.setOptions({
    ...其他配置,
    series: [
      {
        type: 'radar',
        symbolSize: 3,
        symbol: 'circle',
        data: dataArr.value, //这里引用第二个ref
        areaStyle: {
          color: '#d4dbf2',
          opacity: 0.5,
        },
      })
}
const handleValue = () => { // 更新数据函数
  if (dataValue.value.length >= 4) {
    dataValue.value = []
  }
  data.value.map(item => {
    dataValue.value.push(item.value) //在这儿去更新第一个ref
  })
}
watchEffect(() => {
  // watchEffect-> 更新数据 重新加载echart图表
  data.value = props.slelectData
  handleValue()
  update(props.selectValue)
})

✅我的做法

大体逻辑

起初,我认为是深层嵌套或者复杂数据类型的问题,我选择枚举法

第一步

我写了个demo测试,如下所示:我点击按钮让 ref1 改变为about,查看ref2和ref3的视图和值是否更改

javascript 复制代码
// Js
const ref1 = ref<string>('home')
const ref2 = ref<{ x: string }>({
  x: ref1.value
})
const ref3 = ref<{ y: string }[]>([
  { y: ref1.value }
])
const handleChangeRef = () => {
  console.log('点击了按钮改变数据->')
  ref1.value = 'about'

  console.log('ref2->', ref2.value)
  console.log('ref3->', ref3.value)
}
    // dom
    <div>ref1: {ref1.value}</div>
    <div>ref2的x属性: {ref2.value.x}</div>
    <div>ref3: {ref3.value[0].y}</div>
    <button onClick={handleChangeRef}>点击改变为about</button>

测试结果-> ref1更改成功、ref2和ref3视图和数据均未改变 所以复杂数据类型是不行的 在这里,ref2 的属性x 确实引用了ref1.value 的当前值。但是,ref2 本身是一个独立的ref 对象,它只在初始化时获取了ref1.value 的值。它不会自动跟踪ref1 的变化。

第二步

测试简单数据类型

javascript 复制代码
const ref4 = ref<string>(ref1.value)
const handleChangeRef = () => {
  console.log('点击了按钮改变数据->')
  ref1.value = 'about'

  console.log('ref2->', ref2.value)
  console.log('ref3->', ref3.value)
  console.log('ref4->', ref4.value)
}

测试结果->简单数据类型也不行 ref4 的值是从ref1.value 直接赋值的,而不是引用ref1 本身。因此,当您更改ref1 时,ref4 不会自动更新,因为它只是获取了ref1.value 的当前值。

枚举结果就出来了:不是复杂类型的问题那么就是使用的问题了

第三步

解决问题-> 使用计算属性或者watch来定义不会产生这样的问题

javascript 复制代码
const ref2 = computed(() => {
  return {
    x: ref1.value
  }
})

🎦结论

回顾描述与评价

这个问题(对象的引用和复制),我想我以前一定经常看,但实际遇到,还是没有想起来。 说明自身的经验不足,纸上谈兵是没有用的。 对自己的反思......


具体的知识(对象的引用和复制)可以在开头看到地址,可以回顾一下 不论是Vue还是React都会遇到这样的问题

最后,有用点个赞吧? 👀

相关推荐
弹简特4 分钟前
【JavaEE03-前端部分】JavaScript入门:给网页注入灵魂,从基础到实战玩转交互!
前端·javascript·交互
天人合一peng5 分钟前
unity获得和修改button的text(TMP)
java·前端·unity
jiayong236 分钟前
Vue 3 面试题 - 状态管理与数据流
前端·javascript·vue.js
摇滚侠2 小时前
npm 设置了阿里云镜像,然后全局安装了 pnpm,pnpm 还需要设置阿里云镜像吗
前端·阿里云·npm
程序员清洒8 小时前
Flutter for OpenHarmony:GridView — 网格布局实现
android·前端·学习·flutter·华为
VX:Fegn08958 小时前
计算机毕业设计|基于ssm + vue超市管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
0思必得09 小时前
[Web自动化] 反爬虫
前端·爬虫·python·selenium·自动化
LawrenceLan9 小时前
Flutter 零基础入门(二十六):StatefulWidget 与状态更新 setState
开发语言·前端·flutter·dart
秋秋小事9 小时前
TypeScript 模版字面量与类型操作
前端·typescript
2401_892000529 小时前
Flutter for OpenHarmony 猫咪管家App实战 - 添加提醒实现
前端·javascript·flutter