$set()处理数据更新但视图不更新的问题

踩了一个坑,给对象加完属性,打印出来了,但是页面没渲染出来。

原因是:受 ES5 的限制,Vue.js 不能检测到对象属性的添加或删除。因为 Vue.js 在初始化实例时将属性转为 getter/setter,所以属性必须在 data 对象上才能让 Vue.js 转换它,才能让它是响应的。

要处理这种情况,可以使用$set()方法,既可以新增属性,又可以触发视图更新。

调用方法:Vue.set( target, key, value )

this.$set(‘对象名’,要修改的属性名,属性值),这样新添加的属性值会被Vue监听到并且同步渲染到页面上

你可能感兴趣的:(vue)