当前位置: 首页 > wzjs >正文

磨床 东莞网站建设sem竞价托管价格

磨床 东莞网站建设,sem竞价托管价格,石家庄网站开发价格,国外低代码平台文章目录 前言代码解析 Vue3使用示例 Vue3vue2 写法 前言 在前端开发中,我们常常会遇到需要检测用户是否点击了某个元素外部的场景,比如弹出框在用户点击外部时需要关闭。接下来我们来封装一个 clickOutside 自定义指令 代码解析 Vue3 import { Direc…

文章目录

      • 前言
      • 代码解析 Vue3
      • 使用示例 Vue3
      • vue2 写法

前言

在前端开发中,我们常常会遇到需要检测用户是否点击了某个元素外部的场景,比如弹出框在用户点击外部时需要关闭。接下来我们来封装一个 clickOutside 自定义指令

代码解析 Vue3

import { Directive } from 'vue';// 定义 ClickOutside 指令类型
const clickOutside: Directive<HTMLElement, () => void> = {// 当指令绑定到元素并插入到 DOM 中时调用mounted(el: HTMLElement, binding) {// 定义事件处理函数,类型注解表明它接收一个 MouseEvent 类型的参数const handler = (event: MouseEvent) => {// 判断点击的目标元素是否不在绑定指令的元素内部if (!el.contains(event.target as Node)) {// 调用绑定指令时传入的回调函数binding.value();}};// 给 document 添加 click 事件监听器document.addEventListener('click', handler);// 将事件处理函数存储在元素的自定义属性上,方便后续移除监听器el.__clickOutsideHandler = handler;},// 当指令所绑定的元素从 DOM 中移除时调用unmounted(el: HTMLElement) {// 移除之前添加到 document 上的 click 事件监听器document.removeEventListener('click', el.__clickOutsideHandler);// 删除元素上存储的事件处理函数属性delete el.__clickOutsideHandler;},
};export default clickOutside;

使用示例 Vue3

<template><div class="index"><div class="box"><div>举个例子</div><div class="more" @click="moreClick">···</div><divclass="more-box"v-if="moreShow"v-click-outside="handleClickOutside"><div>干嘛呢</div><div>干嘛呢</div><div>干嘛呢</div><div>干嘛呢</div></div></div></div>
</template><script setup lang="ts">
import { ref, Directive } from "vue";const moreShow = ref(false);function moreClick(event: any) {console.log("更多被戳了一下");moreShow.value = !moreShow.value;event.stopPropagation();
}function handleClickOutside() {moreShow.value = false;
}
</script><style scoped lang="scss">
.index {overflow: hidden;
}.box {width: 300px;height: 160px;border: 1px solid #00000055;border-radius: 10px;padding: 10px;margin: 100px;position: relative;
}.more {cursor: pointer;text-align: center;width: 30px;height: 30px;position: absolute;top: 10px;right: 10px;
}.more-box {position: absolute;right: -20px;width: 90px;border: 1px solid #00000055;border-radius: 10px;background: #ffffff;padding: 10px 0px;div {line-height: 36px;text-align: center;}
}
</style>

在这里插入图片描述

vue2 写法

const clickOutside = {// 当指令第一次绑定到元素时调用,在这里进行初始化设置bind: function (el, binding) {// 定义事件处理函数,用于处理 document 的 click 事件const handler = function (event) {// 判断点击的目标元素是否不在绑定指令的元素内部if (!el.contains(event.target)) {// 调用绑定指令时传入的回调函数binding.value();}};// 给 document 添加 click 事件监听器document.addEventListener('click', handler);// 将事件处理函数存储在元素的自定义属性上,方便后续移除监听器el.__clickOutsideHandler = handler;},// 当指令与元素解绑时调用,在这里进行清理工作unbind: function (el) {// 移除之前添加到 document 上的 click 事件监听器document.removeEventListener('click', el.__clickOutsideHandler);// 删除元素上存储的事件处理函数属性delete el.__clickOutsideHandler;}
};export default clickOutside;
http://www.dtcms.com/wzjs/503835.html

相关文章:

  • html5公司网站源码郑州网站推广公司咨询
  • 旅游设计专业网站2023年8月疫情爆发
  • c#做交易网站关键帧
  • 买个域名多少钱一年徐州百度seo排名优化
  • 如何在淘宝网做自己的网站域名大全
  • 网站开发需要用什么软件企拓客软件怎么样
  • 厦门做手机网站公司拉新推广赚钱的app
  • 从化网站建设seo博客推广
  • 丽水品牌网站建设央视新闻的新闻
  • 如何建立自已的购物网站软文广告是什么
  • 功能网站合肥网站排名推广
  • 廊坊外贸网站建设可口可乐搜索引擎营销案例
  • 施坦威网站关于我们班级优化大师官网
  • 眼查看网站开发语言网站广告调词软件
  • 做公司年报网站登录密码是什么收录是什么意思
  • 济南正规做网站公司最有效的app推广方式有哪些
  • 好的手机网站推荐百度搜索推广多少钱
  • 网站建设营销排名方案外贸推广平台哪个好
  • 磁力猫郑州纯手工seo
  • 如何在相关网站免费做宣传广告百度商家平台
  • 国外网站制作有哪些沈阳seo网站关键词优化
  • html5 手机网站 模板网站页面优化方案
  • 上海金融网站制作网站制作公司好网站友情链接的作用
  • 中国人民解放军文职考试一年几次百度seo排名工具
  • 南宁网站seo优化公司怎么申请域名建网站
  • 梅州建网站百度竞价排名平台
  • 网站服务器报价培训后的收获和感想
  • 自己建站模板写一篇软文1000字
  • 长沙php网站建设刷关键词排名系统
  • 手机网站模版php源码百度搜索指数排行榜