Vue3 学习笔记,如何理解 Computed 计算属性

开发 前端
Computed 计算属性是基于它们的依赖进行缓存的,这意味着只有在它们的依赖发生变化时,才会重新计算。这使得它们更高效,因为它们只在需要时才会计算,而不是每次都调用。

大家好,本篇文章我们继续学习和 Vue 相关的内容,今天我们归纳总结下什么是 computed 计算属性、如何使用和应用场景,以及 computed 和 Method 事件的区别和应用场景。

什么是 computed 计算属性

Vue.js 中的 computed 计算属性是一种特殊类型的属性,它们的值不是简单地被设置,而是根据其它属性的值计算得出。

computed 计算属性是基于它们的依赖进行缓存的,这意味着只有在它们的依赖发生变化时,才会重新计算。这使得它们更高效,因为它们只在需要时才会计算,而不是每次都调用。

下面是一个示例,展示了如何使用 computed 计算属性:

<template>
  <div>
    <p>Full name: {{ fullName }}</p>
    <input v-model="firstName">
    <input v-model="lastName">
  </div>
</template>

<script>
export default {
  data() {
    return {
      firstName: 'John',
      lastName: 'Doe'
    }
  },
  computed: {
    fullName() {
      return this.firstName + ' ' + this.lastName
    }
  }
}
</script>

在这个例子中,当 firstName 或 lastName 发生变化时,fullName 会自动重新计算。

computed 和 method 事件的区别

与 computed 计算属性不同的是,methods 方法是每次都会调用的,不能进行缓存。如果你需要在每次渲染时都计算一个值,那么使用 methods 方法会更好。

下面是一个使用 methods 方法的示例:

<template>
  <div>
    <p>Full name: {{ getFullName() }}</p>
    <input v-model="firstName">
    <input v-model="lastName">
  </div>
</template>

<script>
export default {
  data() {
    return {
      firstName: 'John',
      lastName: 'Doe'
    }
},
  methods: {
    getFullName() {
      return this.firstName + ' ' + this.lastName
    }
  }
}
</script>

在这个例子中,每次渲染时都会调用 getFullName 方法,而不是缓存其结果。

总结一下

适用 computed 计算属性的场景是:

  • 适合一些简单的操作,比如数组排序或筛选
  • 计算属性可以直接在HTML中使用,像 Data 中的属性一样使用。
  • 当你需要基于其它属性计算一个新的值。
  • 当你需要缓存计算结果,因为这样能提高应用的性能。

适用 methods 方法的场景是:

  • 当你需要在每次渲染时都计算一个值。
  • 当你需要执行一些复杂的逻辑或者需要调用外部函数。
  • 方法通常作为事件监听或公共业务逻辑
  • 方法可以当做普通 JS 函数使用

另外,计算属性是可以被观察的,可以被用在指令和计算属性依赖中。而 method 方法不能被观察到,不能用在指令和计算属性依赖中。

再举一个例子:

<template>
  <div>
    <p>Price: {{ price }}</p>
    <p>Discount: {{ discount }}%</p>
    <p>Discounted price: {{ discountedPrice }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      price: 100,
      discount: 10
    }
  },
  computed: {
    discountedPrice() {
      return this.price * (1 - this.discount / 100)
    }
  }
}
</script>

在这个例子中,discountedPrice 是基于 price 和 discount 计算得出的,并且当 price 或 discount 发生变化时,discountedPrice 会自动重新计算。 而如果用 method 实现的话,每次都会计算一遍,而不是只在需要时计算。

总之,computed 计算属性是一种高效的方式,能够基于其它属性进行计算并缓存结果,而 methods 方法则是每次都会调用并进行计算。

结束

今天的内容就介绍到这里,内容比较简单,希望对你有所帮助。

责任编辑:姜华 来源: 今日头条
相关推荐

2021-12-08 09:09:33

Vue 3 Computed Vue2

2024-05-27 08:39:17

Vue3变量响应式

2023-11-28 09:03:59

Vue.jsJavaScript

2023-12-06 07:43:56

Vue如何定义事件

2021-12-01 08:11:44

Vue3 插件Vue应用

2021-12-02 05:50:35

Vue3 插件Vue应用

2021-11-30 08:19:43

Vue3 插件Vue应用

2021-11-16 08:50:29

Vue3 插件Vue应用

2022-06-26 00:00:02

Vue3响应式系统

2021-12-29 07:51:21

Vue3 插件Vue应用

2023-12-14 08:25:14

WatchVue.js监听数据

2022-07-14 08:22:48

Computedvue3

2021-11-17 08:24:47

Vue3 插件Vue应用

2023-11-29 08:49:31

Vue.jsData 函数

2021-11-26 05:59:31

Vue3 插件Vue应用

2022-04-11 08:03:30

Vue.jscomputed计算属性

2024-11-06 10:16:22

2021-12-14 21:43:13

Vue3函数computed

2022-07-20 11:13:05

前端JSONVue3

2020-09-19 21:15:26

Composition
点赞
收藏

51CTO技术栈公众号