vue基础-$set的使用

一、vue的双向数据绑定

js 复制代码
    <ul>
      <li v-for="item of list" :key="item.id">
        姓名:{{ item.name }}----年龄:{{ item.age }}
      </li>
    </ul>
    <el-button @click="addUser">添加人员</el-button>
    
  data() {
    return {
      list: [
        { id: 1, name: '小明', age: 18 },
        { id: 2, name: '小华', age: 19 },
        { id: 3, name: '小华' }
      ]
    }
  }
  
  方法:
    addUser() {
      this.list.push({ id: Date.now(), name: 'xx', age: '未知' })
    }

如上这段代码,可以看到,定义在data中的list,可以往里面push一条新的数据,数据改变,视图就会更新

二、数据改变,但是不会更新视图的情况

js 复制代码
<el-button @click="changeUser">改变人员</el-button>




    changeUser() {
      this.list[2].age = 100
    }

在data中定义list的时候,第三项数据并没有age属性,现在,我们来改变它,但是视图并没有任何改变。

原因呢?因为在data中定义list的时候,并没有定义第三项的age属性,那么这个属性就不会经过Object.defineProperty来处理,所以当改变age时,就不会触发视图的更新

三、如何触发视图更新

  1. 改变整个数组
js 复制代码
      this.list = this.list.map((item, index) => ({
        ...item,
        age: index === 2 ? 100 : item.age
      }))
  1. 使用$set
js 复制代码
      this.$set(this.list[2], 'age', 100)

同样地,如果你想通过length去删除数组的最后一项this.list.length = this.list.length - 1也是不行的,使用this.$delete(this.list, this.list.length - 1)便可以。

相关推荐
NiceCloud喜云7 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby8 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩8 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思9 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫11 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。12 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星12 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒12 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩12 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi12 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具