vue数组变化视图_vue 在使用数组的时候,数组内部数据发生变化,视图却没有改变...

data(){return{

todos: [

{name:'aa', age: 22},

{name:'bb', age: 23}

]

}

}

methods:{

changeTodos(){this.todos[0]={name: 'zz', age: 12}

}

}

上面我们在改变todos中的数据的时候,页面则没有改变,我们可以使用下面的方法来解决这个问题

1.使用全局set方法

this.$set(this.todos, 0, {name: 'zz', age: 12})

this.$set(this.todos[0], 'name', 'zz')

2.强制更新

this.$forceUpdate()

如果我们不想利用$set去设置,可以利用$forceUpdate,因为修改了数据但是页面层没有变动,说明数据本身被修改了,只是vue没有监听到而已,用$forceUpdate就相当于按照最新数据给渲染一下

changeTodos(){

this.todos[0]={name: 'zz', age: 12}

this.$forceUpdate();

}

监听vue中数组的变化,

如果只是监听数组列表项的增减即数组长度的改变,直接对数组进行监听就好了

watch:{

data(newVal, oldVal) {

// do

}

}

如果是要对数组列表项的内容是否发生改变做监听,则需要加上一个deep: true属性

watch: {

data: {

handler(newVal, oldVal) {//do

},

deep:true}

}

这个属性时深度监听,可以监听到对象,数组的内容变化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值