[db:标题]
- 内容介绍
- 文章标签
- 相关推荐
本文共计537个文字,预计阅读时间需要3分钟。
在我们项目的开发过程中,实例中的数据类型可以是对象、数组等。在对象中,当某个属性的值发生变化时,我们可以通过对象的深度监听,实现页面内容的自动刷新,以满足重新渲染页面的需求。或者,可以查阅本文了解详情。
在我们项目开发过程中,实例中的数据类型可以是对象、数组等。在对象中,某个属性值发生更改时,我们可以通过对象的深度监听,以达到重新渲染页面的需求。或者查阅这篇文章
例如:
<script> export default { data(){ return { objVal: { name: 'obj', type: 'obj' } } }, watch:{ objVal:{ handler(val,oldval){ }, deep: true, } }, methods:{ changeObj(){ this.objVal.name = 'newobj'; } } } </script>
但是,在使用同一种方式进行数组值更改监听时,这种做法是无效的。
<script> export default { data() { return { arrList: [1,2,3,4,5] }; }, watch: { arrList: { handler(val, oldval) { }, deep: true } }, methods: { changeArr() { // 无效 this.arrList[0] = 10; } } }; </script>
上述用以监听数组值变化的方法是无效的,vue是不会响应数据变化而重新去渲染页面。在vue中仅需要通过修改赋值语句的方式,即可让vue响应数组数据的变化。
本文共计537个文字,预计阅读时间需要3分钟。
在我们项目的开发过程中,实例中的数据类型可以是对象、数组等。在对象中,当某个属性的值发生变化时,我们可以通过对象的深度监听,实现页面内容的自动刷新,以满足重新渲染页面的需求。或者,可以查阅本文了解详情。
在我们项目开发过程中,实例中的数据类型可以是对象、数组等。在对象中,某个属性值发生更改时,我们可以通过对象的深度监听,以达到重新渲染页面的需求。或者查阅这篇文章
例如:
<script> export default { data(){ return { objVal: { name: 'obj', type: 'obj' } } }, watch:{ objVal:{ handler(val,oldval){ }, deep: true, } }, methods:{ changeObj(){ this.objVal.name = 'newobj'; } } } </script>
但是,在使用同一种方式进行数组值更改监听时,这种做法是无效的。
<script> export default { data() { return { arrList: [1,2,3,4,5] }; }, watch: { arrList: { handler(val, oldval) { }, deep: true } }, methods: { changeArr() { // 无效 this.arrList[0] = 10; } } }; </script>
上述用以监听数组值变化的方法是无效的,vue是不会响应数据变化而重新去渲染页面。在vue中仅需要通过修改赋值语句的方式,即可让vue响应数组数据的变化。

![[db:标题]](/imgrand/mK1qfQk2.webp)