react 自定义鼠标右键点击事件

功能:鼠标右键点击节点时,出现"复制"功能,点击其他部位,隐藏"复制";鼠标右键事件的文案,始终在鼠标点击位置的右下方;点击复制,提示复制成功

效果图:

代码:

复制代码
const [showRight,setShowRight] = useState(false);
const contextMenu = useRef(null); 
const [clickX,setClickX] = useState('0px');
const [clickY,setClickY] = useState('0px');

------------

<div className='topology-node' onContextMenu={(e)=> handleRight(e)} >
	这里面是图中的节点,只有右键双击图中节点,才会触发自定义的右键事件功能
</div>

------------

// 鼠标右键展示的内容,注意这里的样式rightStyle,鼠标右键时菜单的位置(图中"复制"的位置)就是靠这个样式控制的
{showRight&&<div className='right-panel' onClick={handleRightCopy} style={rightStyle}>复制</div>}

------------

useEffect(()=>{
	// 监听其他地方的点击事件
    document.addEventListener('click', _handleClick);
})

------------

// 事件
const handleRight =(event:any) =>{
    setShowRight(true)
    // event.clientX event.clientY 鼠标相对于浏览器窗口可视区域的X,Y坐标(窗口坐标)
    setClickX(event.clientX);  
    setClickY(event.clientY);
}
// 右键菜单的位置,加减多少看自己,位置看着舒服就行
const rightStyle = {
    left:`${clickX + 5}px`,
    top: `${clickY + 5}px`
}
const _handleClick =(event:any)=>{
    const wasOutside = !(event.target.contains === contextMenu);
    // 点击其他位置需要隐藏右键菜单
    if (wasOutside) setShowRight(false);
}
const handleRightCopy =()=>{
    console.log('点击了复制');
    message.success('复制成功')
}

css

复制代码
// 样式可以自定义
.right-panel{
  width: 100px;
  z-index:10;
  position: fixed;
  background-color: pink;
  cursor: pointer;
}
相关推荐
Highcharts.js6 小时前
React 图表如何实现下钻(Drilldown)效果
开发语言·前端·javascript·react.js·前端框架·数据可视化·highcharts
SuperEugene8 小时前
TypeScript+Vue 实战:告别 any 滥用,统一接口 / Props / 表单类型,实现类型安全|编码语法规范篇
开发语言·前端·javascript·vue.js·安全·typescript
We་ct9 小时前
LeetCode 35. 搜索插入位置:二分查找的经典应用
前端·算法·leetcode·typescript·个人开发
发现一只大呆瓜10 小时前
React-深度拆解 React路由:从实战进阶到底层原理
前端·react.js·面试
发现一只大呆瓜11 小时前
React-手把手带你实现 Keep-Alive 效果
前端·react.js·面试
张一凡9312 小时前
重新理解 React 状态管理:用类的方式思考业务
前端·react.js
zhensherlock13 小时前
Protocol Launcher 系列:App Store 精准引流与应用推广
javascript·macos·ios·typescript·iphone·mac·ipad
codingWhat14 小时前
从 React 无痛过渡到 React Native
react native·react.js
zhensherlock14 小时前
Protocol Launcher 系列:Trae AI 编辑器的深度集成
javascript·人工智能·vscode·ai·typescript·编辑器·ai编程
ETA815 小时前
状态管理没那么复杂:手写实现 Zustand 核心逻辑
前端·react.js