返回

vue中this.$set修改数组,数据改变视图层不更新

发布时间:2023-02-10 08:22:44 329
# 数据

this.$set( target, propertyName/index, value )用法:

  1. ​{Object | Array} target​
  2. ​{string | number} propertyName/index​
  3. ​{any} value​

(官方解释)

  • 用法
    向响应式对象中添加一个 property,并确保这个新 property 同样是响应式的,且触发视图更新。它必须用于向响应式对象上添加新 property,因为 Vue 无法探测普通的新增 property (比如 this.myObject.newProperty = 'hi')
  • 总结
    1、动态修改的数据必须在data
    2、修改某属性的值数据改变视图层也改变的条件:该属性初始化必须在该属性所在数据源中或者由this.$set做的新增属性,后面对该属性进行操作才能监听到该属性

demo

obj:{
name:"zhangsan",
age:"15"
}
  1. 新增sex属性 ​​this.obj.sex='男'​
  2. 通过对象修改sex属性 ​​this.obj.sex='女'​​,此时数据改变,视图未更新
  3. 通过​​this.$set​​修改​​this.$set(obj,'sex','女')​​ ,发现数据改变,视图未更新,与第2.出现相同的现象
  4. 原因:​​obj​​中没有​​sex​​属性,​​this.$set(obj,'sex','女')​​只能做修改,vue.set( )可以做县呢过,然后对​​obj.sex​​做操作的话才能够监听到​​sex​​,视图层才会更新

相关文章:​​vue.set()与this.$set()的区别​​

特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像
精选文章
thumb 中国研究员首次曝光美国国安局顶级后门—“方程式组织”
thumb 俄乌线上战争,网络攻击弥漫着数字硝烟
thumb 从网络安全角度了解俄罗斯入侵乌克兰的相关事件时间线
下一篇
JS加密高级技巧:分块加密 2023-02-10 07:44:01