methods和computed有什么区别_第2页回答

2021-09-14 14:07发布

13条回答
py大白
2楼 · 2021-09-22 14:02

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,这个就只能是使用监听来处理了,不能使用计算属性


帅帅马
3楼 · 2021-09-27 09:58

computed详解

computed可以完成各种复杂的逻辑,包括运算、函数调用等,只要最终返回一个结果就可以。下面是一个简易的计算器,来实现乘法的操作


长度:
宽度:


面积:

[removed][removed]

[removed]

var vm = new Vue({

el: '#app',

data: {

length: '',

width: '',

},

computed: {

areas: function() {

console.log('调用computed')

return this.length * this.width

}

}

})

[removed]

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24


当在长度文本框和宽度的文本框里输入值的时候,面积会自动给出。这里的 computed 的操作比较简单,返回值也比较好写。但当遇到比较麻烦的操作时,我们就需要返回自定义的返回值。


总价:

[removed][removed]

[removed]

var vm = new Vue({

el: '#app',

data: {

package1: [

{

name: 'iPhone 7',

price: 7199,

count: 2

},

{

name: 'iPad',

price: 2888,

count: 1

}

],

  package2: [

  {

  name: 'apple',

  price: 3,

  count: 5

  },

  {

  name: 'banana',

  price: 2,

  count: 10

  }

  ]

},

computed: {

prices: function() {

var prices = 0

for (var i = 0; i < this>

prices += this.package1[i].price * this.package2[i].count;

}

for (var i = 0; i < this>

prices += this.package2[i].price * this.package2[i].count;

}

return prices

}

}

})

[removed]

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51


自定的 prices 的几个值要保持一致,而且不能与 data 重复,也不需要在 data 里声明。


computed和methods的区别

我们用 computed 属性和 methods 方法编写一个计算器的乘法与加法计算。


长度:
宽度:


面积:


和的值为:

[removed][removed]

[removed]

var vm = new Vue({

el: '#app',

data: {

length: '',

width: '',

num: ''

},

computed: {

areas: function() {

console.log('调用computed')

let areas = 0

areas = this.length * this.width

return areas

/*console.log("computed被调用了")*/

}

},

methods: {

add: function() {

console.log('调用methods')

this.num = parseInt(this.length) + parseInt(this.width)

},

}

})

[removed]

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

 


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

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

目前来看 computed 属性的优势还是没有体现出来,我们再举一个例子。


{{ reversedText }}

[removed][removed]

[removed]

var vm = new Vue({

el: '#app',

data: {

text: '123,456'

},

computed: {

reversedText: function() {

return this.text.split(',').reverse().join(',');

}

}

})

[removed]

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

这个输出的结果就是 456,123


{{ reversedText() }}

[removed][removed]

[removed]

var vm = new Vue({

el: '#app',

data: {

text: '123,456'

},

methods: {

reversedText: function() {

return this.text.split(',').reverse().join(',');

}

}

})

[removed]

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

输出的结果也是 456,123 但两者之间的差别就是在计算结果不发生改变的情况下,computed 的方法只被调用了一次,即便是多处多次调用,computed 也只被调用一次,这就是 computed 缓存的优势。那么在哪些情况下更适合使用 computed ?一般使用简单的表达式对内容进行简单的转换与使用过滤器对内容进行简单的转换用的比较多


4楼 · 2021-09-30 16:30
  1. 在使用时,computed当做属性使用,而methods则当做方法调用

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

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

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


我的网名不再改
5楼 · 2021-10-17 20:43

computed和methods有什么区别


标准而浅显的回答


在使用时,computed当做属性使用,而methods则当做方法调用

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

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

computed具有缓存,而methods没有

更接近底层原理的回答


vue对methods的处理比较简单,只需要遍历methods配置中的每个属性,将其对应的函数使用bind绑定当前组件实例后复制其引用到组件实例中即可


而vue对computed的处理会稍微复杂一些。


当组件实例触发生命周期函数beforeCreate后,它会做一系列事情,其中就包括对computed的处理


它会遍历computed配置中的所有属性,为每一个属性创建一个Watcher对象,并传入一个函数,该函数的本质其实就是computed配置中的getter,这样一来,getter运行过程中就会收集依赖


但是和渲染函数不同,为计算属性创建的Watcher不会立即执行,因为要考虑到该计算属性是否会被渲染函数使用,如果没有使用,就不会得到执行。因此,在创建Watcher的时候,它使用了lazy配置,lazy配置可以让Watcher不会立即执行。


收到lazy的影响,Watcher内部会保存两个关键属性来实现缓存,一个是value,一个是dirty


value`属性用于保存Watcher运行的结果,受`lazy`的影响,该值在最开始是`undefined

dirty`属性用于指示当前的`value`是否已经过时了,即是否为脏值,受`lazy`的影响,该值在最开始是`true

1

2

Watcher创建好后,vue会使用代理模式,将计算属性挂载到组件实例中


当读取计算属性时,vue检查其对应的Watcher是否是脏值,如果是,则运行函数,计算依赖,并得到对应的值,保存在Watcher的value中,然后设置dirty为false,然后返回。


如果dirty为false,则直接返回watcher的value


巧妙的是,在依赖收集时,被依赖的数据不仅会收集到计算属性的Watcher,还会收集到组件的Watcher


当计算属性的依赖变化时,会先触发计算属性的Watcher执行,此时,它只需设置dirty为true即可,不做任何处理。


由于依赖同时会收集到组件的Watcher,因此组件会重新渲染,而重新渲染时又读取到了计算属性,由于计算属性目前已为dirty,因此会重新运行getter进行运算


而对于计算属性的setter,则极其简单,当设置计算属性时,直接运行setter即可


IT学习助手 - qq:2676427015
6楼 · 2022-03-26 09:41

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;

5)1491741921719$vm0.method_now;

6)()1491741949941$vm0.method_now;

7)()1491741950734$vm0.method_now;

8)()1491741951445$vm0.method_now;

9)()1491741952117。

5、methods是方法和原生js没区别,大多是需要我们主动调用(比如事件)。

6、computed是get 这个get有点特殊,只要触发所依赖数据的set会自动触发get。我们只关心get的return set由系统触发或者依赖的数据触发,官方说依赖缓存只是为了理解。其实Date.now()这种只是系统不能触发set,不能触发set get当然不会通知观察者。

7、watch 是set 由data触发,我们可以在set里进行自己的条件封装。


相关问题推荐

  • 回答 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 的基础上增加了一些数据...

  • 回答 52
    已采纳

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

  • 回答 11

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

  • 回答 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 看看这个 

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