场景:在列表中,有这么一个属性,需要通过同行的其他属性,进行复杂的计算,才能得出,如果我们用方法,然后传参,得到这个属性,那么每次更改列表后,每行都会重新计算,耗费性能。如果我们有一个可缓存的方法,在参数没有改变的时候,返回之前得到的缓存结果。只有在参数改变的时候,重新计算。
我们可以构建一个工具函数,将计算函数作为参数,会返回一个带缓存的函数。如下 useComputed.js:
// useComputed.js
import { computed } from "vue";export function useComputed(fn) {const cache = new Map();function getCache(args) {return cache.get(JSON.stringify(args));}return function (...args) {const cacheResult = getCache(args);if (cacheResult) {return cacheResult;}const result = computed(() => fn(...args));cache.set(JSON.stringify(args), result);return result;};
}
使用:
<template> {{ computedPrice(row) }} </template><script setup>import { useComputed } from "./useComputed.js";function totalPrice(row) {return row.price * row.count;}const computedPrice = useComputed(totalPrice);
</script>