问答

Vue文档说利用数组索引直接设置一个数组项时不能检测到变动,但

作者:admin 2021-04-19 我要评论

let app = new Vue({ data() { return { msg: 'this is msg', arr: [{ name: 1 }, { name: 2 }, { name: 3 }] } }, mounted() { this.arr[1].name = 'change-mou...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)
    let app = new Vue({
        data() {
            return {
                msg: 'this is msg',
                arr: [{
                    name: 1
                }, {
                    name: 2
                }, {
                    name: 3
                }]
            }
        },
        mounted() {
            this.arr[1].name = 'change-mounted'
            setTimeout(() => {
                this.msg = 'change'
                this.arr[2].name = 'chagne 2'
            }, 2000)
        },
        methods: {
            click() {
                this.arr[0].name = '3'
            }
        }
    }).$mount('#app')

既然不能检测到数组中的变化,为什么页面数据还是变了呢?

###

我贴下原文吧
vue检测变化的注意事项

对于数组

Vue 不能检测以下数组的变动:

  1. 当你利用索引直接设置一个数组项时,例如:vm.items[indexOfItem] = newValue
  2. 当你修改数组的长度时,例如:vm.items.length = newLength

举个例子:

var vm = new Vue({
  data: {
    items: ['a', 'b', 'c']
  }
})
vm.items[1] = 'x' // 不是响应性的
vm.items.length = 2 // 不是响应性的

为了解决第一类问题,以下两种方式都可以实现和 vm.items[indexOfItem] = newValue 相同的效果,同时也将在响应式系统内触发状态更新:

// Vue.set
Vue.set(vm.items, indexOfItem, newValue)
// Array.prototype.splice
vm.items.splice(indexOfItem, 1, newValue)

你也可以使用 vm.$set 实例方法,该方法是全局方法 Vue.set 的一个别名:

vm.$set(vm.items, indexOfItem, newValue)

为了解决第二类问题,你可以使用 splice

vm.items.splice(newLength)
###

你理解错了,说的是这种直接索引赋值:

mounted() {
    setTimeout(() => {
        this.arr[2] = { name: 'change 2' };
    }, 2000)
}

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • nginx响应速度很慢

    nginx响应速度很慢

  • 点击选中的多选框,会在已选那一栏显示

    点击选中的多选框,会在已选那一栏显示

  • PHP 多态的理解

    PHP 多态的理解

  • 关于C语言中static的问题

    关于C语言中static的问题

腾讯云代理商
海外云服务器