当前位置: 首页 > article >正文

vue如何做到计算属性传参?

1.计算属性传参,还在return一个函数?

let nameFull = computed(() => {
    return e => {
        console.log('参数', e)
    }
})

那这样的话,干脆直接写一个函数

2.真正的计算属性传参,借助map实现

import { computed } from "vue";
export function zlcComputed(fn) {
  const map = new Map();
  return function (...args) {
    const key = JSON.stringify(args);
    if (map.has(key)) {
      return map.get(key);
    }
    const res = computed(() => {
      return fn(...args);
    });
    map.set(key, res);
    return res;
  };
}
<template>
  <div class="hello">{{ firstName("章") }}</div>
  <div class="hello">{{ firstName("龙") }}</div>
</template>

<script setup>
import { zlcComputed } from "@/utils/zlcComputed";
let firstName = zlcComputed((data) => {
  return data;
});
</script>

<style scoped>

</style>

3.有些人会有疑问,还不是每次都会走zlcComputed中return出来的函数?没错,但是万一设计到复杂的好性能的计算呢?如果使用步骤一的方法return一个函数,每次都会重新运行,而使用这种方式直接从map中取出结果返回,没有设计到计算。


http://www.kler.cn/a/301796.html

相关文章:

  • css出现边框
  • Perturbed-Attention Guidance(PAG) 笔记
  • 【算法】算法大纲
  • STM32-笔记37-吸烟室管控系统项目
  • [Git] git pull --rebase / git rebase origin/master
  • MakeFile使用指南
  • 研1日记9
  • 【C++多线程编程】 线程安全与对象生命周期管理
  • Docker Compose与私有仓库部署
  • 10分钟在企业微信中集成一个 AI 助手
  • 汽车EDI:montaplast EDI对接
  • XWiki中添加 html 二次编辑失效
  • C# WinForm:禁用Panel容器滚动条自动移动位置的功能
  • leetcode 刷题周报(9.3-9.10)
  • java框架第五课(终极版本)SpringBoot
  • QT 中使用QXlsx 读写文件
  • Linux学习-Docker文件系统
  • 3. 轴指令(omron 机器自动化控制器)——>MC_PowerMC_MoveJog
  • mysql的zip解压缩版安装
  • MySQL根据日期统计时没有数据的日期也需要返回0
  • 图计算:基于SparkGrpahX计算聚类系数
  • 在Linux系统中“普通场景”下隐匿操作痕迹
  • 算法学习攻略总结 : 入门至进阶,通关之路指南
  • jmeter依赖jar包找不到类路径
  • CTF(misc)
  • 微调语言模型前,需要考虑这三个关键方面