vue中添加原生右键菜单

vue 复制代码
<div
  v-show="state.contextMenu.visible"
  class="context-menu"
  :style="{
	left: `${state.contextMenu.x}px`,
	top: `${state.contextMenu.y}px`
  }"
>

数据结构定义

javascript 复制代码
const state = reactive({
    contextMenu: {
        visible: false,
        x: 0,
        y: 0,
        currentItem: null
    }
});


// 新增右键菜单处理函数
const handleContextMenu = (event, item) => {
    event.preventDefault();
    state.contextMenu = {
        visible: true,
        x: event.clientX,
        y: event.clientY,
        currentItem: item
    };
};

const closeContextMenu = () => {
    state.contextMenu.visible = false;
};


onMounted(async () => {
	document.addEventListener('click', closeContextMenu);    
);

在需要触发的组件中调用

vue 复制代码
 @contextmenu="handleContextMenu($event, item)"

样式定义

css 复制代码
/* 新增右键菜单样式 */
.context-menu {
  position: fixed;
  background: white;
  border: 1px solid #ebeef5;
  border-radius: 4px;
  box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
  z-index: 9999;
  min-width: 120px;
}

.menu-item {
  padding: 8px 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
}

.menu-item:hover {
  background-color: #f5f7fa;
  color: var(--el-color-primary);
}
相关推荐
绝世唐门三哥4 小时前
使用Intersection Observer js实现超出视口固定底部按钮
开发语言·前端·javascript
南山安4 小时前
Vue学习:ref响应式数据、v-指令、computed
javascript·vue.js·面试
思茂信息4 小时前
CST电动车EMC仿真——电机控制器MCU滤波仿真
javascript·单片机·嵌入式硬件·cst·电磁仿真
小胖霞4 小时前
企业级全栈 RBAC 实战 (11):菜单管理与无限层级树形表格
vue.js·前端框架·前端工程化
鲸落落丶4 小时前
Vue Router路由
前端·javascript·vue.js
米方4 小时前
ElementPlus 穿梭框支持批量穿梭
前端·javascript·vue.js
InkHeart4 小时前
uni-app开发路上的坑
前端·vue.js
还算善良_4 小时前
【Vue】表格实现表头多彩
javascript·vue.js·ecmascript
JS_GGbond5 小时前
用Canvas和SVG制作简单动画:从零开始的视觉魔法
javascript
努力学习的少女5 小时前
对SparkRDD的认识
开发语言·前端·javascript