useFormItem.ts 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import type { UnwrapRef, Ref, WritableComputedRef, DeepReadonly } from 'vue';
  2. import { reactive, readonly, computed, getCurrentInstance, watchEffect, unref, nextTick, toRaw } from 'vue';
  3. import { isEqual } from 'lodash-es';
  4. export function useRuleFormItem<T extends Recordable, K extends keyof T, V = UnwrapRef<T[K]>>(
  5. props: T,
  6. key?: K,
  7. changeEvent?,
  8. emitData?: Ref<any[] | undefined>
  9. ): [WritableComputedRef<V>, (val: V) => void, DeepReadonly<V>];
  10. export function useRuleFormItem<T extends Recordable>(props: T, key: keyof T = 'value', changeEvent = 'change', emitData?: Ref<any[]>) {
  11. const instance = getCurrentInstance();
  12. const emit = instance?.emit;
  13. const innerState = reactive({
  14. value: props[key],
  15. });
  16. const defaultState = readonly(innerState);
  17. const setState = (val: UnwrapRef<T[keyof T]>): void => {
  18. innerState.value = val as T[keyof T];
  19. };
  20. watchEffect(() => {
  21. innerState.value = props[key];
  22. });
  23. const state: any = computed({
  24. get() {
  25. //修复多选时空值显示问题
  26. return innerState.value === '' ? [] : innerState.value;
  27. },
  28. set(value) {
  29. if (isEqual(value, defaultState.value)) return;
  30. innerState.value = value as T[keyof T];
  31. nextTick(() => {
  32. emit?.(changeEvent, value, ...(toRaw(unref(emitData)) || []));
  33. });
  34. },
  35. });
  36. return [state, setState, defaultState];
  37. }