vue中修改数组或者对象后,无法触发双向绑定

本文介绍在Vue.js中如何正确使用$set方法来更新数组和对象的属性,以确保视图能够响应数据变化。文章通过两个示例,演示了直接修改数组和对象属性时页面不更新的问题,并展示了$set方法的正确用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

修改data中的数组,数组发生改变,页面未发生改变

  • 可通过$set方法来设置数组的值,该方法有三个参数,第一个是要被设置值的目标对象,第二个是设置值在数组中的索引,第三个是要设置的值
<template>
  <div class="home">
    <ul>
      <li v-for="(item, index) in demoArr"
          :key="index">
        {{item}}
      </li>
    </ul>
    <button @click="btn1">button1</button>
    <button @click="btn2">button2</button>
  </div>
</template>

<script>

export default {
  name: 'Home',
  data () {
    return {
      demoArr: [1, 2, 3]
    }
  },
  methods: {
    btn1 () {
      this.demoArr[0] = this.demoArr[0] + 1
    },
    btn2 () {
      this.$set(this.demoArr, 0, this.demoArr[0] + 1)
    }
  }
}
</script>

修改对象的属性,但是页面的值没有发生改变

<template>
  <div class="home">
    <ul>
      <li>
        {{demoObj.demo}}
      </li>
    </ul>
    <button @click="btn1">button1</button>
    <button @click="btn2">button2</button>
  </div>
</template>

<script>

export default {
  name: 'Home',
  data () {
    return {
      demoObj: {
        // demo: ''   1、 直接初始化这个属性
      }
    }
  },
  created () {
    // this.btn1()
  },
  methods: {
    btn1 () {
      this.demoObj.demo = 'aaaaa'
      //  这个时候属性会添加失败,原因是demo属性没有预先初始化
    },
    btn2 () {
      // 通过$set来设置
      this.$set(this.demoObj, 'demo', 'aaa')
    }
  }
}
</script>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值