vue数值改变进不了watch监听事件,以及vue数据改变不渲染问题。

原文链接:https://blog.csdn.net/weixin_46002631/article/details/123135208
可参考链接:https://blog.csdn.net/bigbear00007/article/details/102594645
vue渲染以及监听问题
举个例子
vue数值改变进不了监听以及渲染问题。
vue官方中说明了侦听数组的改变方法,若是使用索引去改变数组的参数则不会触发vue的watch事件以及渲染。例如↓

1.通过索引直接设置数组的某个值,
this.objArr[index] = newValue;
2.通过索引直接设置数组中对象的某个属性,
this.objArr[index].pro = newValue;
3.通过修改数组的长度,
this.objArr.length = newLength;
以上三种情况都是不会触发vue的监听以及渲染的。

解决方法
官方文档中说明了:改变vue变更方法
一共有七种,都会进入watch以及触发vue视图更新。
image
如下

this.arr[index] = newValue;通过索引直接设置数组的某个值,是不会触发watch以及视图更新。
那我们就用他给的方法:splice()
splice()的使用方法我放在最后,若有不会的可提供参考。

this.arr.splice(index,1,newValue) //这样就会触发vue的watch以及视图的更新。

splice()的使用方法
image

\\我自己的使用
selectFn(val,index,expand){
            let y = this.form.list[index]
            y.value = val
            this.form.list.splice(index,1,y)
        },
posted @ 2022-11-08 10:35  Chaplink  阅读(1241)  评论(0编辑  收藏  举报