Vue 自定义指令实现点击元素外触发事件, 带参数的回调函数,并且可以在v-for列表使用

122 阅读1分钟
/**是列表的元素本身的触发事件能带参 */
Vue.directive('clickout', {
  // 初始化指令
  bind(el, binding, vnode) {
    function clickHandler(e) {
      // 这里判断点击的元素是否是本身,是本身,则返回
      if (el.contains(e.target)) {
        return false;
      }
      // 判断指令中是否绑定了函数
      if (binding.expression) {
        // 如果绑定了函数 则调用那个函数,此处binding.value就是handleClose方法
        // binding.value(e);
        // 这里进行了修改, 使用arg 传递函数名称, 使用value 传递 变量值
        // console.log("接收到 的arg为: " + funcName)
        console.log("接收到的 value 为: " + binding.value)
        let that = vnode.context
        that[binding.arg](binding.value)
      }
    }
    // 给当前元素绑定个私有变量,方便在unbind中可以解除事件监听
    el.__vueClickOutside__ = clickHandler;
    document.addEventListener('click', clickHandler);
  },
  update() {},
  unbind(el, binding) {
    // 解除事件监听
    document.removeEventListener('click', el.__vueClickOutside__);
    delete el.__vueClickOutside__;
  }
})
 <div v-for="(item, index) in List"
  :key="index">
   <div v-clickout:handleClose="index"></div>
</div>
handleClose(index){}