Vue3 中 Computed 用法

Computed 又被称作计算属性,用于动态的根据某个值或某些值的变化,来产生对应的变化,computed 具有缓存性,当无关值变化时,不会引起 computed 声明值的变化。 产生一个新的变量并挂载到 vue 实例上去。

vue3 中 的 computed 的使用,由于 vue3 兼容 vue2 的选项式 API,所以可以直接使用 vue2 的写法,以下是 vue3 中 computed 的写法和 vue2 中的写法的对比。

组合式 API 中使用 computed 时,需要先引入:import { computed } from "vue"。 引入之后 computed 可以传入的参数有两种: 回调函数和 options 。 具体使用

一、函数式写法

在 vue2 中,computed 写法:

javascript 复制代码
computed:{  
  sum(){  
    return this.num1+ this.num2  
  } 
}

在 vue3 如果使用选项式 API 也可以这样写,主要看下组合式 API 的使用。

示例 1:求和

javascript 复制代码
import { ref, computed }  from "vue"

export default { 
  setup(){  
    const num1 = ref(1)  
    const num2 = ref(1)  
    let sum = computed(()=>{  
      return num1.value + num2.value   
    }) 
  }
}

调用 computed 时, 传入了一个箭头函数,返回值作为 sum 。相比之前,使用更加简单了。如果需要计算多个属性值,直接调用就可以。如:

javascript 复制代码
let sum = computed(()=>{
  return num1.value + num2.value 
})
let mul = computed(()=>{  
  return num1.value * num2.value  
})

二、options 写法

计算属性默认只有 getter ,在需要的时候也可以提供 setter 。在 vue2 中用法如下:

javascript 复制代码
computed:{ 
 mul:{  
  get(){ // num1 值改变时触发    
    return this.num1 * 10   
  },  
  set(value){ // mul 值被改变时触发    
    this.num1 = value /10   
  }  
 } 
}

mul 属性是给 num1 放大 10,如果修改 mul 的值,则 num1 也随之改变。

在 vue3 中 :

javascript 复制代码
let mul = computed({ 
  get:()=>{   
    return num1.value *10 
  }, 
  set:(value)=>{   
    num1.value = value/10 
  } 
})

这两种写法不太一样,仔细观察区别不大,get 和 set 调用也是一样的。

三、computed 传参

计算属性需要传入一个参数怎么写呢?

javascript 复制代码
<template> 
  <div>  
    <div v-for="(item,index) in arr" :key="index" @click="sltEle(index)">    
      {{item}}   
    </div>
  </div>
</template>
<script>
import { ref, computed,reactive } from "vue"

export default{ 
  setup(){   
    const arr = reactive([    '哈哈','嘿嘿'   ])  
    const sltEle = computed( (index)=>{   
      console.log('index',index);   
    })  
    return{ arr,sltEle }
  } 
}
</script>

直接这样写,运行的时候,出现错误:Uncaught TypeError: $setup.sltEle is not a function。

原因:

computed 计算属性并没有给定返回值,我们调用的是一个函数,而 computed 内部返回的并不是一个函数,所以就会报错:sltEle is not a function。

解决办法:

需要在计算属性 内部返回一个函数。修改代码如下:

javascript 复制代码
const sltEle = computed(()=>{ 
  return function(index) {  
    console.log('index',index);
  } 
}
相关推荐
lichenyang45310 分钟前
JSAPI、NAPI、Biz、Imp:ASCF Demo 如何真正调用系统能力和 C++ 能力
前端
lichenyang45330 分钟前
IPC、JSVM、UIThread、libuv:ASCF 架构图里最容易混的几个词
前端
用户0595401744634 分钟前
Redis记忆存储故障恢复测试踩坑实录:手动测试让我漏掉了2个一致性Bug
前端·css
用户21366100357236 分钟前
Vue2脚手架工程化与Axios集成
前端·vue.js
用户831348593069839 分钟前
Cesium实现黄昏效果:按钮一键控制打开/关闭黄昏效果,滑块拖动实时控制黄昏浓烈度
vue.js·cesium
张元清41 分钟前
React useDebounce Hook:给状态和回调做防抖(2026)
javascript·react.js
我不是外星人43 分钟前
我把 Claude Code 搬到网页!自研高颜值 Web 交互工作台
前端·ai编程·claude
mixuecoding1 小时前
零成本搭建全球科技热点情报站:12 个平台,6 小时,0 元
前端
用户059540174461 小时前
用了3年Mock,才发现Redis记忆存储的测试一直漏掉了60%的边界场景
前端·css
石小石Orz1 小时前
AI具身交互:实现一个会说话的3D虚拟伴侣
前端·人工智能·后端