vue2给对象新增、删除属性,界面不刷新 。通过数组下标修改数组界面不会刷新

 一、vue2给对象新增、删除属性,界面不刷新

1.新增

1)、解决方法一

this.$set( 对象, 添加的属性, 添加的属性值)

例如:this.$set( this.person, 'sex', '女') 这是在person对象中添加一个sex属性值为女   页面会刷新

 2)、解决方法二

import Vue from 'vue'
Vue.set(this.person,  'sex',  '女')

2.删除

1)、解决方法一

this.$delete( 对象, 删除的属性)

this.$delete( this.person, 'sex')这是在person对象中删除一个sex属性   页面会刷新

 2)、解决方法二

import Vue from 'vue'
Vue.delete(this.person,  'sex')

二、通过数组下标修改数组界面不会刷新

1)、解决方法一
this.$set(数组, 索引, '修改的新值' )

 2)、解决方法二
数组.splice(0, 1, '逛街')        修改数组的第一个索引值为逛街

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
vue组件中的数组的值发生变化时,界面不会自动刷新的问题可能是由于以下原因所导致的: 1. 直接修改数组vue中直接修改数组的值时,vue组件并不能监听到值的变化,并自动更新界面。这是因为vue组件只数组的方法(如push、pop、splice等)调用时才能够监听到值的变化。 因此,如果要让数组的值发生变化时自动更新界面,需要使用vue提供的数组方法。 例如,可以使用vue提供的Vue.set或Vue.delete方法来修改数组的值,这样vue组件就能够监听到值的变化,并自动更新界面。 2. 数据变动未能触发vue监听器 在vue中,通过监听器(watcher)来监控数据的变化并更新界面。但是,在某些情况下,vue的监听器可能无法自动监控到数据变化。 例如,在向数组中添加新元素时,如果添加的元素的类型是对象,而且未使用vue提供的Vue.set方法,那么vue的监听器就无法自动监控到对象属性变化。这时需要手动使用Vue.set方法来设置新对象属性。 3. 异步更新数据 如果数据更新是在一个异步函数内完成的,那么vue组件可能无法即时监听到数组的变化。解决这个问题的方法是使用vue提供的nextTick方法,在vue更新队列刷新之后再执行异步函数。 总之,当vue数组中值发生变化时,界面刷新的问题可能出现在多个方面,需要仔细排查才能找到问题所在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值