如何在鼠标点击指定元素以外的元素时 触发事件

1. 思路

步骤一:通过React.useRef()获取指定元素;

步骤二:给document对象添加点击事件;

步骤三:通过ref.current.contains()函数判断点击的元素是否是当前元素;

步骤四:如果不是当前元素(非指定元素)则执行想要的事件;

2. 代码

javascript 复制代码
const Box = (props: any) => {
  const ref = useRef(null);

  const handleClickOutside = (event) => {
    if (!ref.current) return;
    if (!ref?.current?.contains?.(event.target)) {
      // 在这里执行你需要的操作
      console.log('你没有点击Box');
    } else {
      console.log('你点击了Box');
    }
  };

  useEffect(() => {
    // 添加事件监听器到document
    document.addEventListener('click', handleClickOutside, true);
    return () => {
      // 组件卸载时移除监听器
      document.removeEventListener('click', handleClickOutside, true);
    };
  }, []);

  return (
    <div ref={ref}>
        指定元素
    </div>
  );
};

export default Box;
相关推荐
一只小阿乐2 小时前
react 封装弹框组件 传递数据
前端·javascript·react.js
533_3 小时前
[element-plus] el-tree 动态增加节点,删除节点
前端·javascript·vue.js
禁止摆烂_才浅3 小时前
前端开发小技巧-【JavaScript】- 获取元素距离 document 顶部的距离
前端·javascript·react.js
wshzd3 小时前
LLM之Agent(二十九)|LangChain 1.0核心组件介绍
前端·javascript·langchain
程序猿_极客3 小时前
Vue 2脚手架从入门到实战核心知识点全解析(day6):从工程结构到高级通信(附代码讲解)
前端·javascript·vue.js·vue2学习笔记
q***71853 小时前
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
java·前端·spring boot
一只小阿乐3 小时前
vue3 使用v-model开发弹窗组件
javascript·vue.js·elementui
web加加3 小时前
vue3 +vite项目页面防f12,防打开控制台
前端·javascript·vue.js
A尘埃4 小时前
大模型应用python+Java后端+Vue前端的整合
java·前端·python
遥遥晚风点点5 小时前
Spark导出数据文件到HDFS
前端·javascript·ajax