methods和computed有什么区别

2021-09-14 14:07发布

7条回答
茄子酱
2楼 · 2021-09-15 09:15
  1. 在使用时,computed当做属性使用,而methods则当做方法调用

  2. computed可以具有getter和setter,因此可以赋值,而methods不行

  3. computed无法接收多个参数,而methods可以

  4. computed具有缓存,而methods没有


沃斯泥蝶
3楼 · 2021-09-15 09:19

用 computed 属性方法编写的逻辑运算,在调用时直接将返回时 areas 视为一个变量值就可使用,无需进行函数调用。computed 具有缓存功能,在系统刚运行的时候调用一次。只有只有当计算结果发生变化才会被调用。比如,我们在长度框与宽度框更改值的时候每次更改 computed 都会被调用一次,很浪费资源。

用 methods 方法编写的逻辑运算,在调用时 add() 一定要加“()”,methods 里面写的多位方法,调用方法一定要有()。methods方法页面刚加载时调用一次,以后只有被调用的时候才会被调用。我们在长度框和宽度框的值输入完以后,点击“+” methods 方法调用一次。这里很明显我们采用 methods 会更节省资源。

————————————————

版权声明:本文为CSDN博主「ly_yanbo」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/ly_yanbo/article/details/88664408


aijingda
4楼 · 2021-09-15 13:49

computed是响应式的,methods并非响应式。

调用方式不一样,computed定义的成员像属性一样访问,methods定义的成员必须以函数形式调用。

computed是带缓存的,只有其引用的响应式属性发生改变时才会重新计算,而methods里的函数在每次调用时都要执行。

computed中的成员可以只定义一个函数作为只读属性,也可以定义get/set变成可读写属性,这点是methods中的成员做不到的。

嘿呦嘿呦拔萝卜
5楼 · 2021-09-15 16:39

1、methods是个方法,比如你点击事件要执行一个方法,这时候就用methods,

2、computed是计算属性,实时响应的,比如你要根据data里一个值随时变化做出一些处理,就用computed。

3、举一个例子帮助理解:

1)

2)

3) [removed]        var vm = new Vue({            el: '#root',            data:data,            methods:{

4)method_now(){                    return Date.now();} },            

5)computed:{                

6)computed_now: function () {                    return Date.now();}} })

7)[removed]

4、控制台访问:

1)$vm0.computed_now;

2)1491741921719$vm0.computed_now;

3)1491741921719$vm0.computed_now;

4)1491741921719$vm0.computed_now;


那些年很冒险的梦。
6楼 · 2021-09-16 09:51

computed
以前的名字叫做ready
是在dom加载后马上执行的。

而methods中的函数,则必须要有一定的触发条件。

一个Ai
7楼 · 2021-09-16 14:28

computed vs methods

比如,我们要在页面上显示A+B的值,

methods方法:reuturn A+B

computed计算属性:return A+B

这样看起来两个是没有区别的,都是可以返回结果,而且当A或者B变化时候都是可以返回正确的结果,这个是没问题的,

但是,如果页面还有一个变量C呢,这个C变化时候页面会重新渲染,这个时候两个就有区别了:methods回去重新执行方法,而computed会读取上一次的缓存,如果有一个很复杂的计算,那对性能就有了无谓的消耗,所以就是为什么在页面上显示多个计算出来的值得时候用了computed计算属性,而不用methods方法

computed vs watch 两者都是可以监听变化、

比如有个需求同样是返回A+B,

computed的写法是return A+B;

watch的写法是:分两步,要监听A,也要监听B

A(){return this.A+this.B},

B(){return this.A+this.B},

这样写法上就有区别了,所以按这个需求我们可以理解下 计算属性就是要返回处理数据的一个监听集合(要监听多个)

当然,两者还有本质上的区别:比如有个需求:A变化时候B的值变为1,这个就只能是使用监听来处理了,不能使用计算属性

羊羊0531
8楼 · 2021-09-16 16:52

而methods中一般都是定义的需要事件触发的一些函数。 每次只要触发事件,就会执行对应的方法。 如果把computed中的方法写到method中会浪费性能。 computed必须返回一个值页面绑定的才能取得值,而methods中可以只执行逻辑代码,可以有返回值,也可以没有