文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue Watch方法不能监听到数组或对象值的改变怎么解决

2023-06-29 18:44

关注

这篇文章主要介绍了Vue Watch方法不能监听到数组或对象值的改变怎么解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue Watch方法不能监听到数组或对象值的改变怎么解决文章都会有所收获,下面我们一起来看看吧。

前言

Vue不能监听到数组和对象值的变化其实和双向绑定的原理有关。Vue双向绑定原理是利用js中的Object.defineproperty重定义对象的GET和SET方法,而同时这种方法存在着缺陷。就是只能监听到对象内已有的值。在监听对象中属性变化的方法中中,无疑是 使用ES6的proxy更为优越。

同时我对Vue中不能监听到数组对象变化也做了试验。代码如下。

 let vm = new Vue({        el: '#app',        data: {            message: 'wxs',            arr:[1,2,3],            obj:{                name:'wxs',                age:21            }        },        methods:{            change:function () {                this.message = 'vue'                this.arr[0]=100                this.obj.name='xxx'            }        },        watch:{            message:function (newValue,oldValue) {                console.log('message改变了')            },            arr:function (newValue,oldValue) {                console.log('arr改变了')            },            obj:function (newValue,oldValue) {                console.log('obj改变了')            }        },        template: `<div><div>{{message}}</div><div>{{arr[0]}}</div><div>{{obj.name}}</div><button @click="change()">改变!</button></div>`    })

很简单的代码,设置按钮改变message,arr,obj的值,同时对这三个值的变化设置监听事件,测试结果如下。

Vue Watch方法不能监听到数组或对象值的改变怎么解决

视图显示三个值都发生了改变,但是Vue只监听到了第一个值的改变。

官方文档给出如下解释

Vue Watch方法不能监听到数组或对象值的改变怎么解决

对此Vue提供了解决办法。

Vue不能监听到数组变化官方文档中提出有以下有两种情况。

一:利用索引直接改变arr的值 如我在button事件中写的(arr[0]=1000)

解决方法 将this.arr[0]=1000改写为Vue可以监听的形式 this.$set(this.arr,0,1000)

this.$set接受三个参数,第一个是需要操作的数组对象,第二个是需要修改的数据的数组下标,第三个是修改后的值。

上图看效果。

将修改arr值得方法修改如下

        methods:{            change:function () {                this.message = 'vue'                this.$set(this.arr,0,100)                this.obj.name='xxx'            }        },

Vue Watch方法不能监听到数组或对象值的改变怎么解决

成功监听

二:直接修改数组的长度 如this.arr.length=3 

来做个测试。我们用修改数组长度得方法删除数组中的值,看看watch能不能监听的到。

        methods:{            change:function () {                this.message = 'vue'                this.arr.length=0                this.obj.name='xxx'            }        },

Vue Watch方法不能监听到数组或对象值的改变怎么解决

结果,监听不到。

解决方法使用js中数组方法arr.splice操作数组达到修改长度的目的。

Vue Watch方法不能监听到数组或对象值的改变怎么解决

看看效果

        methods:{            change:function () {                this.message = 'vue'                this.arr.splice(0,1)                this.obj.name='xxx'            }        },

Vue Watch方法不能监听到数组或对象值的改变怎么解决

我们将数组的第一个值删除,此时数组的第二个值变成了arr[0],渲染到了页面中,watch监听成功。

Vue中无法监听对象属性的添加或者删除

解决方法:this.$set(obj,name,&lsquo;xxx&rsquo;)对对象进行操作时,set接受三个参数,第一个为对象的名称,第二个为对象的key值,第三个为key对应的value值。

this.obj=Object.assign({},this.arr,{age:21,major:'soft'})

这样操作之后,便可以成功监听到数组和对象的变化了

methods:{            change:function () {                this.message = 'vue'                              this.$set(this.arr,1,100)                this.$set(this.obj,'major','Vue')            }        },

控制台输出如下

Vue Watch方法不能监听到数组或对象值的改变怎么解决

那么问题来了,我改变的是对象的新值&lsquo;major&rsquo;的值,请注意看我上面代码中method方法中的设置obj的代码。

此时Vue只是监听到了我改变了对象的新值。经过我测试,我改变对象的旧值,比如name值。Vue依然监听不到对象的变化。此时Vue提出了深度监听的方法如下。

Vue Watch方法不能监听到数组或对象值的改变怎么解决

但是这种方法经过我测试不能监听到对象新值的变化。

关于“Vue Watch方法不能监听到数组或对象值的改变怎么解决”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Vue Watch方法不能监听到数组或对象值的改变怎么解决”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯