vue3中的computed

一.computed用法

computed 计算属性就是当依赖的属性的值发生变化的时候,才会触发他的更改;如果依赖的值,不发生变化的时候,使用的是缓存中的属性值。

computed 属性是 Vue3 中的一个响应式计算属性,它可以根据其他响应式数据的变化而自动更新其自身的值。 computed 属性通常用于处理需要根据其他响应式数据计算得出的值的情况,例如过滤和排序、数组计算等。 computed 属性的原理是使用了一个 getter 函数和一个 setter 函数来实现,并将计算结果缓存起来,以提高性能和减少计算次数。

1. 选项式写法:支持一个对象传入get函数和set函数自定义操作

javascript 复制代码
<template>
  姓:<input v-model="firstName" type="text"></input>
  名:<input v-model="lastName" type="text"></input>
  <div>全名:{{ name }}</div>
  <button @click="changeName">测试computed</button>
</template>

<script setup lang="ts">
import { ref, computed } from 'vue'
const firstName = ref('张')
const lastName = ref('三')

// 1. 选项式写法 支持一个对象传入get函数和set函数自定义操作
const name = computed<string>({
  // 读取值
  get() {
    return firstName.value + '-' + lastName.value
  },
  // 写入值
  set(newVal) {
    console.log(newVal); // 李-四
    [firstName.value, lastName.value] = newVal.split('-') // 解构赋值
  }
})
const changeName = () => {
  name.value = '李-四'
}
</script>

<style scoped></style>

输入框中输入文字,全名跟着改变。

点击前:

点击后: set 中接收改变的值,然后赋值给自己想要的属性。

2.函数式写法:只能支持一个getter函数,不允许修改值

javascript 复制代码
<template>
  姓:<input v-model="firstName" type="text"></input>
  名:<input v-model="lastName" type="text"></input>
  <div>全名:{{ name }}</div>
</template>

<script setup lang="ts">
import { ref, computed } from 'vue'
const firstName = ref('张')
const lastName = ref('三')

// 2. 函数式写法 只能支持一个getter函数,不允许修改值
const name = computed(() => { 
  return firstName.value + '-' + lastName.value
})
</script>

输入框中输入文字,全名跟着改变。

使用函数式写法时,属性值为只读的,当想要改变数值时,会报错:

二. computed 原理

在 Vue3 中, computed 属性的原理是使用了一个 getter 函数和一个 setter 函数来实现。当我们访问计算属性的值时,会调用 getter 函数进行计算,并将计算结果缓存起来。当参与计算的响应式数据发生变化时,会触发依赖更新,并自动调用 getter 函数重新计算计算属性的值。当我们修改计算属性的值时,会调用 setter 函数进行更新。

相关推荐
辰同学ovo1 分钟前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
爱看书的小沐5 分钟前
【小沐杂货铺】基于Three.js绘制三维艺术画廊3DArtGallery (Three.js,WebGL)
javascript·3d·webgl·three.js·babylon.js·三维画廊
陈随易22 分钟前
2年没用Nodejs了,Bun很香
前端·后端·程序员
donecoding38 分钟前
Corepack 完全解析:从懵到懂,包管理器自由了
前端·node.js·前端工程化
yqcoder41 分钟前
端经典面试题:为什么 0.1 + 0.2 !== 0.3?
前端·css
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_12:(HTML网页图片嵌入)
前端·javascript·css·ui·html
光影少年1 小时前
reeact虚拟DOM、Diff算法原理、key的作用与为什么不能用index
前端·react.js·掘金·金石计划
用户059540174461 小时前
大模型记忆存储踩坑实录:LangChain 的 ConversationBufferMemory 让我排查了 6 小时
前端·css
是上好佳佳佳呀1 小时前
【前端(十二)】JavaScript 函数与对象笔记
前端·javascript·笔记
你真的快乐吗1 小时前
@fuxishi/svg-icon:一个 Vue 3 svg本地图标+iconify图标组件库,让图标管理不再头疼
前端·vue.js·typescript