methods和computed有什么区别

2021-09-14 14:07发布

13条回答
茄子酱
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中可以只执行逻辑代码,可以有返回值,也可以没有

爱学习的小巴
9楼 · 2021-09-22 09:12

1、methods使用时,一般情况需要加括号,而computed则不需要。2、methods每次调用时会重新执行函数,而computed在其内部变量不变或其返回值不变的情况下多次调用只会执行一次,后续执行时直接从缓存中获取该computed的结果。


相关问题推荐

  • 回答 120

    相对前几年来说,要高上不少了,毕竟入行的人也是越来越多了,基础的工作对应想要参与的人群基数越来越大,但是对于高端人才的需求还是很多,人才还是相对稀缺性的。所以,想要学web或者其他技术也一样,别等,别观望。web前端就业方向特别多包括web前端开发...

  • 回答 25

    相对定位和绝对定位是定位的两种表现形式,区别如下:一、主体不同1、相对定位:是设置为相对定位的元素框会偏移某个距离。2、绝对定位:absolute 脱离文档流,通过 top,bottom,left,right 定位。二、特点不同1、相对定位:在使用相对定位时,无论是否进行移...

  • 抓包是什么意思?2020-04-01 17:36
    回答 7
    已采纳

    抓包(packet capture)就是将网络传输发送与接收的数据包进行截获、重发、编辑、转存等操作,也用来检查网络安全。抓包也经常被用来进行数据截取等。抓包可以通过抓包工具来查看网络数据包内容。通过对抓获的数据包进行分析,可以得到有用的信息。目前流行的...

  • 回答 89

    常用的前端框架有Bootstrap框架、React框架、Vue框架、Angular框架、Foundation框架等等

  • 回答 65
    已采纳

    前端是目的就业前景非常不错的一个计算机技术,但是自学的话还是有一定难度的,网络上自学是碎片化的,同时互联网技术跟新换代快,自己的话比较吃力也学习不到最新的技术。

  • SSR 是什么意思?2020-03-20 18:56
    回答 6

    SSR就是一台服务器,可以利用 SSR 在远程的服务器上配置 SSR,使其能够成为 SSR 节点,这样本地电脑或者其它设备利用 SSR 节点实现 VPN 或者远程上网及游戏加速等方面。ShadowsocksR(简称 SSR)是 Shadowsocks 分支,在 Shadowsocks 的基础上增加了一些数据...

  • 回答 11

    1、代码判断xAxis: {type: 'time',splitLine: {show: false},interval: 3600, // 设置x轴时间间隔axisLabel: {formatter: function(value, index) {return liangTools.unix2hm(value)}}},首先要把xAxis 显示类型设置成time,然后设置对应X轴......

  • 回答 52
    已采纳

    计算机培训方向比较多,建议找适合自己的方向选择培训编程类:JAVA、WEB、Python、C/C++、C#等测试类:软件测试运维类:云计算、网络安全设计类:UI设计、3D建模等

  • 回答 8

    HTML5 + CSS + JavaScript 开发 跨平台重用代码 

  • 回答 4

    采用rem单位自动响应,并提供独有栅格化系统快速定义宽高、边距节省css代码量,同时总结各大型移动端网页,提供一套ui颜色搭配规范,尺寸规范,字体规范等。

  • 回答 10

    iView UI、ioni、SUI

  • 回答 6

     jQTouch 

  • 回答 4

    如果只是普通的移动端用vue react 或者dva 如果是要编译成小程序什么的或者混生 就用uni-app(对应vue语法)taro(对应react) 或者纯原生 这个没有限制的,自己怎么舒服怎么来

  • 回答 4

    因为可以运用在网页和小程序的开饭中,而且开源,用着便宜,企业都很喜欢

  • 回答 10

    一、Visual Studio Code下载地址:https://code.visualstudio.com/微软在2015年4月30日Build 开发者大会上正式宣布了 Visual Studio Code 项目:一个运行于 Mac OS X、Windows和 Linux 之上的,针对于编写现代 Web 和云应用的跨平台源代码编辑器。Visual Stud...

  • 回答 9

    jQuery自带淡入淡出效果 https://www.w3school.com.cn/jquery/jquery_fade.asp 看看这个 

没有解决我的问题,去提问