import { DirectiveOptions } from 'vue'; export const clickoutside: DirectiveOptions = { inserted(el: any, binding: any) { function documentHandler(event: any) { // 这里判断点击的元素是否是本身,是本身,则返回 if (el.contains(event.target)) return false; // 判断指令中是否绑定了函数 if (binding.expression) { // 如果绑定了函数 则调用那个函数,此处binding.value就是handleClose方法 binding.value(); } } // 给当前元素绑定个私有变量,方便在unbind中可以解除事件监听 el.__vueClickOutside__ = documentHandler; document.addEventListener('click', documentHandler); }, update() { }, unbind(el: any, binding: any) { // 解除事件监听 document.removeEventListener('click', el.__vueClickOutside__); delete el.__vueClickOutside__; } };