Vue3前端:计算属性computed与普通方法的区别

结论:computed有缓存,普通方法没有缓存。

  • 对于computed来说,只要依赖的数据发生变化,就会重新计算,重新调用; 但是只要依赖的数据没有发生变化,不管代码用了几次,都只会调用一次。

  • 而普通方法无缓存,代码写了几次,就会调用几次。

1、computed与普通方法对比

下面举例说明: 需求:输入商品单价和购买数量,输出总价。

为突出两种方法在调用上的区别,分别多次调用两种方法,效果如下:

只要依赖的数值不变,即只要"单价"或"数量"不改变,计算属性就只会调用一次。而普通方法,使用多少次就会调用多少次。

代码实现如下:

<template> 复制代码
>  <div class="box">
    单价:<input type="text" v-model="prices">元
    <br>
    数量:<input type="text" v-model="number">个
    <br>
    <br>
    计算属性:
    <br>
    <!-- 计算属性 -->
    商品总价为:{{ totalMoney }} 元<br>
    商品总价为:{{ totalMoney }} 元<br>
    商品总价为:{{ totalMoney }} 元<br>
    商品总价为:{{ totalMoney }} 元<br>
    商品总价为:{{ totalMoney }} 元<br>
    <br>
    方法调用:
    <br>
<!-- 方法调用 -->
    商品总价为:{{ finalMoney() }} 元<br>
    商品总价为:{{ finalMoney() }} 元<br>
    商品总价为:{{ finalMoney() }} 元<br>
    商品总价为:{{ finalMoney() }} 元<br>
    商品总价为:{{ finalMoney() }} 元<br>
  <br>
  <br>

</div>

</template>

<script lang="ts" setup >

import { ref , computed} from 'vue';


let prices=ref(100)
let number=ref(1)

let totalMoney = computed( ()=>{
  console.log("计算属性调用")
  return  prices.value*number.value
  
})

function finalMoney(){
  console.log("方法调用")
  return  prices.value*number.value
}

</script>
<style>
.box{
  background-color: #439eff;
  margin: 20px;
  padding: 20px;
  width: 60%;
}
</style>
2、computed的修改属性

上述代码仅实现的computed的只读属性,是不可修改的。如需修改可以在computed方法体里添加get()和set()方法。这两种方法都是根据依赖值进行再次计算

代码实现如下:

<template> 复制代码
>  <div class="box">
    单价:<input type="text" v-model="prices">元
    <br>
    数量:<input type="text" v-model="number">个
    <br>
    <br>
    计算属性:
    <br>
    <!-- 计算属性 -->
    商品总价为:{{ totalMoney }} 元<br>

  <br>
  <br>
  <button @click="changeMoney">修改单价</button>

</div>

</template>

<script lang="ts" setup >

import { ref , computed} from 'vue';

let prices=ref(100)
let number=ref(1)

let totalMoney = computed( {
  get(){
   
    return prices.value*number.value

  },
  set(){
    // 因为在点击方法里已经改变了prices的值,在这里可以不用写代码,但是必须要添加上set()这个方法,否则只写get()会报错。
    
  }
  
})
function changeMoney(){
   //弹窗输入修改后的金额
  const money = prompt('请输入金额');
  prices.value= Number(money)
}
相关推荐
奋斗吧程序媛7 小时前
补充一个小知识点:有关@click.native
前端·vue.js
英勇无比的消炎药8 小时前
一行命令背后:TinyRobot CLI 如何重构 AI 对话接入的效率范式
vue.js·aigc
jay神10 小时前
基于 FastAPI + Vue 的宠物领养管理系统
前端·vue.js·python·毕业设计·fastapi·宠物
一杯奶茶¥10 小时前
水果销售网站 CRM客户信息管理系统 超市管理系 酒店管理系统 健身房管理系统 在线音乐网站 校园招聘系统
java·vue.js·spring boot·mysql·spring·java项目
英勇无比的消炎药10 小时前
一站式搞定品牌风格:TinyRobot 主题定制从入门到精通
vue.js
尽欢i12 小时前
Vue3 customRef 封神教程:防抖、本地存储、自动埋点一套搞定,模板干干净净
前端·javascript·vue.js
因_崔斯汀12 小时前
Vue 模板编译:HTML 是怎么变成 JS 的?
前端·vue.js
英勇无比的消炎药13 小时前
样式随心定制:TinyRobot 样式覆写与 CSS 变量实战解析
vue.js
疯狂的魔鬼13 小时前
多角色督办任务详情页:从权限矩阵到组件拆分的完整实现
前端·vue.js·架构
英勇无比的消炎药13 小时前
拆解内核:深入分析 TinyRobot 输入区组件设计与实现原理
vue.js