vue.js使用之计算属性与方法返回的差别
2017-08-20 14:34
891 查看
<!DOCTYPE html> <html> <head> <script src="https://unpkg.com/vue@2.4.2"></script> <meta charset="utf-8" /> <title></title> </head> <body> <div id="app-6"> <p v-once v-if="see">{{ message }}</p> <p v-if="see">{{ reversedMessage }}</p> <p v-if="see">{{ reversedMessages() }}</p> <input v-model="message"> <ol> <todo-item v-for="item in groceryList" v-bind:todo="item" v-bind:key="item.id" ></todo-item> </ol> </div> </body> </html> <script> var app6; window.onload = function () { Vue.component('todo-item', { template: '<li>{{todo.text}}</li>', props:['todo'] }) app6 = new Vue({ el: '#app-6', data: { see: true, groceryList: [ { id: 0, text: '蔬菜' }, { id: 1, text: '奶酪' }, { id: 2, text: '随便其他什么人吃的东西' } ], message: 'Hello Vue!' },
//计算属性 computed: { reversedMessage: function () { return this.message.split('').reverse().join('') } },
//方法返回 methods: { reversedMessages: function () { return this.message.split('').reverse().join('') } } }) } </script>
注意 由于计算属性与method 与data中的属性都是保存在app6这个对象的一级属性里面 所以如果重名 后定义的将会覆盖前定义的对象
官方文档解释两者的差别
我们可以将同一函数定义为一个 method 而不是一个计算属性。对于最终的结果,两种方式确实是相同的。然而,不同的是计算属性是基于它们的依赖进行缓存的。计算属性只有在它的相关依赖发生改变时才会重新求值。这就意味着只要
message还没有发生改变,多次访问
reversedMessage计算属性会立即返回之前的计算结果,而不必再次执行函数。
这也同样意味着下面的计算属性将不再更新,因为
Date.now()不是响应式依赖:
computed: { now: function () { return Date.now() } } |
相比而言,只要发生重新渲染,method 调用总会执行该函数。
文档地址 https://cn.vuejs.org/v2/guide/computed.html
相关文章推荐
- vue计算属性的使用和vue实例的方法
- Vue1.0学习总结(3)———vue1.0的生命周期、vue计算属性computed的使用、vue实例(vm)上方法总结、vue结合动画使用
- vue中的计算属性的使用和vue实例的方法示例
- Vue.js中计算属性和方法的区别
- 关于vue的使用计算属性VS使用计算方法的问题
- 使用weight属性时View宽度的计算方法
- UIWebView 的属性、方法的具体使用和详解 与JS的交互
- Vue.js-----轻量高效的MVVM框架(五、计算属性)
- HTML5中自定义的data-*属性使用和js/jquery的data()方法操作
- JS 使用List<Object> 对象中的Object对象的某个属性的临时处理方法
- vue.js计算属性
- Vue.js每天必学之计算属性computed与$watch
- Vue.js基本规则提炼总结及计算属性学习
- Vue.js的计算属性
- Vue.js计算属性
- 在使用JS编程中,有时需要在一个方法返回两个个或两个以上的数据
- JS自定义data-*属性与jquery的data()方法的使用
- JS面向对象(3)之Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
- 使用反射依导航路径调用对象成员方法,或返回对象子、孙属性或字段成员[转]
- 关于android中使用weight属性实现多个layou比例布局的计算方法