vue-vben-admin/packages/hooks/src/useRefs.ts

25 lines
457 B
TypeScript
Raw Normal View History

2021-08-13 00:12:51 +08:00
import type { Ref } from 'vue';
2023-04-06 23:49:20 +08:00
import { onBeforeUpdate, shallowRef } from 'vue';
2020-11-18 22:41:59 +08:00
function useRefs(): {
refs: Ref<HTMLElement[]>;
setRefs: (index: number) => (el: HTMLElement) => void;
} {
2023-04-06 23:49:20 +08:00
const refs = shallowRef([]) as Ref<HTMLElement[]>;
2020-11-18 22:41:59 +08:00
onBeforeUpdate(() => {
refs.value = [];
});
2020-12-10 23:58:11 +08:00
const setRefs = (index: number) => (el: HTMLElement) => {
2020-11-18 22:41:59 +08:00
refs.value[index] = el;
};
return {
refs,
setRefs,
};
2020-11-18 22:41:59 +08:00
}
export { useRefs };