VUE如何实现动态给对象增加属性并触发视图更新操作-创新互联

这篇文章主要介绍了VUE如何实现动态给对象增加属性并触发视图更新操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

创新互联专业提供成都主机托管四川主机托管成都服务器托管四川服务器托管,支持按月付款!我们的承诺:贵族品质、平民价格,机房位于中国电信/网通/移动机房,德阳服务器托管服务有保障!

在开发过程中,我们时常会遇到这样一种情况:当vue的data里边声明或者已经赋值过的对象或者数组(数组里边的值是对象)时,向对象中添加新的属性,如果更新此属性的值,是不会更新视图的。

根据官方文档定义:如果在实例创建之后添加新的属性到实例上,它不会触发视图更新。

Vue 不允许在已经创建的实例上动态添加新的根级响应式属性 (root-level reactive property)。然而它可以使用 Vue.set(object, key, value) 方法将响应属性添加到嵌套的对象上。

我们编写如下代码测试给一个对象动态添加属性:


   
  
var vm=new Vue({   el: "#app",   data: {     i:0,     form:{}   },   methods:{     demoSet(){       this.form.amount=this.i++;       //this.$set(this.form,"amount",this.i++);     }   }   });

这种方式可以给form增加一个属性,但是不会界面不会响应更新。

正确的做法:


   
  
var vm=new Vue({   el: "#app",   data: {     i:0,     form:{}   },   methods:{     demoSet(){       this.$set(this.form,"amount",this.i++);     }   }   });

这样就可以给对象添加amount 属性了。

这个有什么应用场景呢,比如 data.form 属性很多,其中大部分是不需要要的,这时候,可以使用这种方法实现动态添加需要的属性。

需要注意的是,这种方式是不能给根数据添加属性的,比如:


   
  
var vm=new Vue({   el: "#app",   data: {   },   methods:{     demoSet(){       this.$set(this,"name","ray");     }   }   });

这种方式给data 增加一个 name 属性是无效的。

为什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以创建可维护性和可测试性更强的代码库,Vue允许可以将一个网页分割成可复用的组件,每个组件都包含属于自己的HTML、CSS、JavaScript,以用来渲染网页中相应的地方,所以越来越多的前端开发者使用vue。

感谢你能够认真阅读完这篇文章,希望小编分享的“VUE如何实现动态给对象增加属性并触发视图更新操作”这篇文章对大家有帮助,同时也希望大家多多支持创新互联成都网站设计公司,关注创新互联成都网站设计公司行业资讯频道,更多相关知识等着你来学习!

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、网站设计器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前题目:VUE如何实现动态给对象增加属性并触发视图更新操作-创新互联
文章位置:http://azwzsj.com/article/ggdpi.html

其他资讯