Vue中的methods与computed有什么区别
Vue中的methods与computed有什么区别?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
设计一个计算成绩和的案例:
<!DOCTYPE html><html lang="en">
<head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>计算属性与监听器</title> <!-- 引入Vue.js --> <script src="./node_modules/vue/dist/vue.js"></script> </head> <body> <div id="app"> 数学:<input type="text" v-model="mathScore"> 英语:<input type="text" v-model="englishScore"><br> <!-- 注意:调用methods的方法一定要加括号 --> 总分(methods方式):<input type="text" v-model="sumScore()"><br> <!-- 注意:调用computed里面的方法不要加括号 --> 总分(computed,纯get方式):<input type="text" v-model="sumScore1"><br> 总分(computed,get+set方式):<input type="text" v-model="sumScore2"> </div> <script> var vm = new Vue({ el: '#app', data: { mathScore: 80, englishScore: 60 }, methods: { sumScore: function () { console.log("methods方式调用!"); return (this.mathScore - 0) + (this.englishScore - 0); } }, computed: { // 默认是纯get方式,也是单项绑定 sumScore1: function () { console.log("compute的纯get方式调用"); return (this.mathScore - 0) + (this.englishScore - 0); }, // 采用get加set方式 sumScore2: { get: function () { console.log("compute的get方式调用"); return (this.mathScore - 0) + (this.englishScore - 0); }, // 当在输入框中更改了总分后,两项成绩就会分别取到新总分的平均值,从而实现双向绑定 set: function (newValue) { console.log("compute的set方式调用"); var avgScore = newValue / 2; this.mathScore = avgScore; this.englishScore = avgScore; } } } }) </script> </body> </html>
总结methods与computed区别:
- 1.调用方式不同。computed直接以对象属性方式调用,不需要加括号,而methods必须要函数执行才可以得到结果。
- 2.绑定方式不同。methods与compute纯get方式都是单向绑定,不可以更改输入框中的值。compute的get与set方式是真正的双向绑定。
- 3.是否存在缓存。methods没有缓存,调用相同的值计算还是会重新计算。competed有缓存,在值不变的情况下不会再次计算,而是直接使用缓存中的值。
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注行业资讯频道,感谢您对亿速云的支持。