Vue computed 计算属性代码实例
什么是计算属性???
1、在computed中,可以定义一些属性,这些属性叫做【计算属性】
2、计算属性的本质是一个方法,不过一般是将他们的名称直接当做属性使用,不会当方法调用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <script src="../lib/vue-2.4.0.js"></script> </head> <body> <div id="app"> <input type="text" v-model="firstname">+ <input type="text" v-model="lastname">= <input type="text" v-model="fullname"> </div> <script> var vm = new Vue({ el: '#app', data: { firstname: '', lastname: '' }, methods: {}, computed:{ // 在computed中,可以定义一些属性,这些属性叫做【计算属性】 // 计算属性的本质是一个方法,不过一般是将他们的名称直接当做属性使用,不会当方法调用 'fullname':function () { return this.firstname + '-' + this.lastname; } } }) </script> </body> </html>
重点注意
1、计算属性,在调用的时候,一定不要加()去调用,直接将它当做普通属性使用
2 、计算属性的function中引用的data中的数据发生了变化,就会立即重新计算这个计算属性的值
3、 计算属性的求值结果,会被缓存起来,方便下次直接使用;如果计算属性方法中,所有来的任何数据没有发生改变,则不会重新计算
内容扩展
vue之computed(计算属性)的使用方法
在vue中,一些简易的计算可以直接在模板中计算,如:{{ number + 1 }};但是在模板中如果有太多复杂的计算难以维护;所以对于任何复杂的逻辑,你都应该使用计算属性的原因;
1.经过处理返回的数据值,只要源数据没有发生改变,computed函数里面对相应的数据就不会反生改变,相当于缓存在本地;发生改变的时候,computed对应数据的函数也会发生改变;
2:computed属性和methods属性
你可能已经注意到我们可以通过调用method来达到同样的效果:我们可以将同一个函数定义为一个method而不是一个计算属性,对于最终的结果,两种方式确实是相同的;
然而,计算属性是基于他们的依赖就行缓存的,计算属性只有在它相关的依赖发生改变时才会重新求值,这意味着只要message 还没有发生改变,多次访问reversedMessage计算属性会立刻返回之前计划算的结果,而不必再次执行函数.
3:computed中的属性;
计算属性默认只有getter不过在需要时也可以提供一个setter;
var vm=new Vue({ el:"#demo", data:{ firstName:"foo", lastName:"Bar", fullName:"foo Bar" }, computed:{ fullName:function(){ get:function(){ return this.firstName+" "+this.lastName; }, setter:function(){ var names=newValue.split(''); this.firstName=names[0]; this.lastName=names[names.length-1] } } } });
到此这篇关于Vue computed 计算属性代码实例的文章就介绍到这了,更多相关Vue之computed 计算属性内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!