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