「Vue3系列」Vue3 计算属性(computed)、监听属性(watch)

本文涉及的产品
性能测试 PTS,5000VUM额度
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: 在 Vue 3 中,计算属性(Computed Properties)是一种强大的功能,它允许你声明一个依赖于其他响应式数据属性的属性,并且这个属性的值会根据其依赖的数据的变化而自动更新。计算属性是基于它们的依赖关系进行缓存的,只有在它的相关依赖发生改变时才会重新求值。

一、Vue3 计算属性(computed)

在 Vue 3 中,计算属性(Computed Properties)是一种强大的功能,它允许你声明一个依赖于其他响应式数据属性的属性,并且这个属性的值会根据其依赖的数据的变化而自动更新。计算属性是基于它们的依赖关系进行缓存的,只有在它的相关依赖发生改变时才会重新求值。

下面是如何在 Vue 3 中使用计算属性的一个简单示例:

<template>
  <div>
    <p>原始值:{
  { message }}</p>
    <p>计算后的值:{
  { reversedMessage }}</p>
    <button @click="message = 'Hello World!'">修改原始值</button>
  </div>
</template>

<script>
import {
     ref, computed } from 'vue';

export default {
    
  setup() {
    
    const message = ref('Hello Vue3');

    const reversedMessage = computed(() => {
    
      return message.value.split('').reverse().join('');
    });

    return {
    
      message,
      reversedMessage
    };
  }
}
</script>

在这个例子中,我们有一个响应式引用 message,它包含一个字符串。我们还定义了一个计算属性 reversedMessage,它返回 message 的逆序字符串。当 message 的值发生变化时,reversedMessage 的值也会自动更新。

在 Vue 3 的 Composition API 中,我们使用 setup 函数来定义组件的逻辑。在这个函数中,我们可以使用 ref 来创建响应式引用,使用 computed 来创建计算属性。

计算属性在处理复杂逻辑或计算时非常有用,因为它们可以缓存结果,只有在依赖的数据发生变化时才会重新计算,这有助于提高性能。

二、Vue3 计算属性的getter与setter

在 Vue 3 中,计算属性不仅仅是一个简单的计算结果的缓存,它们还允许你定义一个 setter 函数,该函数会在你尝试修改计算属性的值时触发。这为你提供了一种方式来观察或拦截对计算属性的更改。

下面是一个使用 getter 和 setter 的计算属性示例:

<template>
  <div>
    <p>计算属性的值:{
  { computedValue }}</p>
    <button @click="incrementComputedValue">增加计算属性的值</button>
  </div>
</template>

<script>
import {
     ref, computed } from 'vue';

export default {
    
  setup() {
    
    const baseValue = ref(1);

    const computedValue = computed({
    
      get() {
    
        return baseValue.value * 2; // Getter
      },
      set(newValue) {
    
        baseValue.value = newValue / 2; // Setter
      }
    });

    function incrementComputedValue() {
    
      // 直接修改计算属性的值会触发 setter
      computedValue.value += 1;
    }

    return {
    
      computedValue,
      incrementComputedValue
    };
  }
}
</script>

在这个例子中,computedValue 是一个计算属性,它有一个 getter 和一个 setter。getter 函数返回 baseValue 的两倍,而 setter 函数接受一个新的值,并将其除以 2 来更新 baseValue

当你尝试通过 computedValue.value = someValue 修改计算属性的值时,setter 会被调用。在上面的示例中,当你点击按钮时,incrementComputedValue 函数会增加 computedValue 的值,这会触发 setter,导致 baseValue 被适当地更新。

需要注意的是,计算属性的 setter 并不常见,因为计算属性通常用于基于其他响应式属性的只读值。如果你需要一个可以设置的值,通常最好使用普通的响应式引用(ref)或响应式对象(reactive)。然而,在某些特殊情况下,你可能需要计算属性的 setter 来执行一些自定义逻辑,例如在值改变时发送通知或执行副作用。

三、Vue3 监听属性(watch)

在 Vue 3 中,如果你想要监听某个属性的变化并在变化时执行某些操作,你可以使用 watch 函数或 watchEffect 函数。这两个函数都在 setup 函数内部可用,是 Vue 3 Composition API 的一部分。

使用 watch 函数

watch 函数允许你监听一个或多个响应式引用或计算属性的变化,并在它们变化时执行一个回调函数。

<template>
  <div>
    <p>被监听的属性值:{
  { count }}</p>
    <button @click="incrementCount">增加</button>
  </div>
</template>

<script>
import {
     ref, watch } from 'vue';

export default {
    
  setup() {
    
    const count = ref(0);

    // 使用 watch 监听 count 的变化
    watch(count, (newValue, oldValue) => {
    
      console.log(`Count changed from ${
      oldValue} to ${
      newValue}`);
      // 在这里执行你想要的任何操作
    });

    function incrementCount() {
    
      count.value++;
    }

    return {
    
      count,
      incrementCount
    };
  }
}
</script>

在这个例子中,我们创建了一个响应式引用 count 并使用 watch 来监听它的变化。每当 count 的值改变时,回调函数都会被调用,并打印出旧值和新值。

使用 watchEffect 函数

watchEffect 函数则会自动收集依赖,并在依赖发生变化时重新运行一个给定的函数。这个函数不需要显式地指定依赖项。

<template>
  <div>
    <p>被监听的属性值:{
  { count }}</p>
    <button @click="incrementCount">增加</button>
  </div>
</template>

<script>
import {
     ref, watchEffect } from 'vue';

export default {
    
  setup() {
    
    const count = ref(0);

    // 使用 watchEffect 监听依赖的变化
    watchEffect(() => {
    
      console.log(`Count is now ${
      count.value}`);
      // 在这里执行你想要的任何操作
    });

    function incrementCount() {
    
      count.value++;
    }

    return {
    
      count,
      incrementCount
    };
  }
}
</script>

在这个例子中,watchEffect 会自动检测 count.value 的变化,并在每次变化时运行提供的函数。

对比 watchwatchEffect

  • watch 需要你显式地指定要监听的响应式引用或计算属性,并且你可以访问变化前后的值。
  • watchEffect 则会自动收集其函数内部的依赖,并在这些依赖变化时重新运行该函数。它不需要你指定依赖项,但你不能直接访问变化前后的值(不过你可以通过闭包或其他方式来间接访问)。

选择使用哪一个取决于你的具体需求和你想要如何组织你的代码。如果你需要更细粒度的控制或需要访问变化前后的值,那么 watch 可能是更好的选择。如果你想要更简洁的语法并且不关心具体的依赖项,那么 watchEffect 可能会更适合你。

四、Vue3 computed与watch比较

在 Vue 3 中,computedwatch 各自有不同的用途,并且服务于不同的目的。以下是它们的比较:

computed(计算属性)

  • 用途:用于声明一个依赖于其他响应式数据属性的属性,并且这个属性的值会根据其依赖的数据的变化而自动更新。计算属性是基于它们的依赖关系进行缓存的,只有在它的相关依赖发生改变时才会重新求值。

  • 特点

    • 响应式:计算属性是响应式的,当依赖的数据变化时,计算属性会自动更新。
    • 缓存:计算属性会缓存其结果,只有当依赖的属性发生变化时才会重新计算。
    • 只读:计算属性默认是只读的,你不能直接修改它们的值。尝试这样做会导致警告或错误。
    • Getter 和 Setter:你可以为计算属性提供 getter 和 setter 函数,以控制属性的读取和写入行为。
  • 适用场景:当你需要根据其他响应式数据动态计算出一个新值时,使用计算属性。

watch(监听属性)

  • 用途:用于观察一个或多个响应式数据属性的变化,并在它们变化时执行一个回调函数。

  • 特点

    • 观察变化watch 用于观察数据属性的变化,并在数据变化时触发回调。
    • 灵活性:你可以选择监听特定的属性,并且可以访问变化前后的值。
    • 自动或手动watch 可以是自动的(通过 watchEffect),也可以是手动的(通过 watch),取决于你是否想要显式指定依赖。
    • 执行回调:当监听的数据变化时,watch 会执行提供的回调函数。
  • 适用场景:当你需要在数据变化时执行某些副作用操作(如发送请求、更新DOM等)时,使用 watch

总结

  • computed 适用于根据其他响应式数据动态计算出一个新值,并且这个值需要被频繁读取的场景。
  • watch 适用于在数据变化时需要执行某些操作(如副作用)的场景,特别是当你需要访问变化前后的值或需要执行异步操作时。

五、相关链接

  1. Vue3官方地址
  2. Vue3中文文档
  3. 「Vue3系列」Vue3简介及安装
  4. 「Vue3系列」Vue3起步/创建项目
  5. 「Vue3系列」Vue3指令
  6. 「Vue3系列」Vue3 模板语法
  7. 「Vue3系列」Vue3 条件语句/循环语句
  8. 「Vue3系列」Vue3 组件
相关文章
|
1月前
|
JavaScript 前端开发 API
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
1月前
|
存储 数据采集 供应链
属性描述符初探——Vue实现数据劫持的基础
属性描述符还有很多内容可以挖掘,比如defineProperty与Proxy的区别,比如vue2与vue3实现数据劫持的方式有什么不同,实现效果有哪些差异等,这篇博文只是入门,以后有时间再深挖。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
5月前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
5月前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
5月前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
JavaScript
Vue -computed传参数
vue 中computed想传递参数怎么办? 闭包在这里起到的重要的作用 &lt;input v-model="newItem(key,val)" type="text"/&gt; computed:{ newIt...
3056 0
|
4月前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
203 1
|
1月前
|
JavaScript 前端开发 算法
vue渲染页面的原理
vue渲染页面的原理
118 56
|
21天前
|
SQL JavaScript 前端开发
Vue实现动态数据透视表(交叉表)
Vue实现动态数据透视表(交叉表)
127 13
|
1月前
|
数据采集 资源调度 JavaScript
极致的灵活度满足工程美学:用Vue Flow绘制一个完美流程图
本文介绍了使用 Vue Flow 绘制流程图的方法与技巧。Vue Flow 是一个灵活强大的工具,适合自定义复杂的流程图。文章从环境要求(Node.js v20+ 和 Vue 3.3+)、基础入门案例、自定义功能(节点与连线的定制、事件处理)到实际案例全面解析其用法。重点强调了 Vue Flow 的高度灵活性,虽然预定义内容较少,但提供了丰富的 API 支持深度定制。同时,文中还分享了关于句柄(handles)的使用方法,以及如何解决官网复杂案例无法运行的问题。最后通过对比 mermaid,总结 Vue Flow 更适合需要高度自定义和复杂需求的场景,并附带多个相关技术博客链接供进一步学习。