mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
feat: add use-click-outside hook
This commit is contained in:
parent
b6549ed721
commit
f329fd9f6f
23
src/hooks/use-click-outside.ts
Normal file
23
src/hooks/use-click-outside.ts
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
import { Ref, onMounted } from 'vue';
|
||||||
|
import { useHandler } from './use-handler';
|
||||||
|
|
||||||
|
export type UseClickOutsideOpitons = {
|
||||||
|
event: string;
|
||||||
|
callback: EventListener;
|
||||||
|
element: Ref<Element>;
|
||||||
|
flag?: Ref<boolean>;
|
||||||
|
};
|
||||||
|
|
||||||
|
export function useClickOutside(options: UseClickOutsideOpitons) {
|
||||||
|
const { event = 'click', callback, element, flag } = options;
|
||||||
|
|
||||||
|
function onClick(event: Event) {
|
||||||
|
if (!element.value.contains(event.target as Node)) {
|
||||||
|
callback(event);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
useHandler(document, event, onClick, false, flag);
|
||||||
|
});
|
||||||
|
}
|
@ -9,16 +9,16 @@ import {
|
|||||||
} from 'vue';
|
} from 'vue';
|
||||||
|
|
||||||
export function useHandler(
|
export function useHandler(
|
||||||
target: HTMLElement | Document | Window,
|
target: EventTarget,
|
||||||
event: string,
|
event: string,
|
||||||
handler: any,
|
handler: EventListener,
|
||||||
passive = false,
|
passive = false,
|
||||||
ref?: Ref<boolean>
|
flag?: Ref<boolean>
|
||||||
) {
|
) {
|
||||||
let binded: boolean;
|
let binded: boolean;
|
||||||
|
|
||||||
function add() {
|
function add() {
|
||||||
if (binded || (ref && !ref.value)) {
|
if (binded || (flag && !flag.value)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,9 +33,9 @@ export function useHandler(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ref) {
|
if (flag) {
|
||||||
watch(() => {
|
watch(() => {
|
||||||
ref.value ? add() : remove();
|
flag.value ? add() : remove();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user