vue项目1分钟实现自定义右键菜单,懒人的福音

高效实现需求,避免重复造轮子,今天给大家分享的是,如何在最短的时间内实现右键菜单,方法也很简单,一个插件就可以搞定,话不多说,上效果图:

1. 效果图:

在这里插入图片描述

2. 安装:

npm install vue-contextmenujs

yarn add vue-contextmenujs

3. 引入:

在main.js中引入
import Contextmenu from “vue-contextmenujs”
Vue.use(Contextmenu);

4. 代码实现:

4.1 在需要实现自定义右键的元素上加上 @contextmenu.prevent=“onContextmenu”:
<div style="width:100vw;height:100vh" @contextmenu.prevent="onContextmenu">
	<div>右键</div>
</div>
4.2 在methods中添加方法:
  // 鼠标右键事件
  onContextmenu(event) {
    this.$contextmenu({
        items: this.contextMenuData,
        event, // 鼠标事件信息
        customClass: 'custom-class', // 自定义菜单 class
        zIndex: 3, // 菜单样式 z-index
        minWidth: 230 // 主菜单最小宽度
    });
    return false;
  },
4.3 contextMenuData 的数据如下:
 data() {
    return {
      contextMenuData: [
        {
          label: "置顶会话",
          // 以element-ui图标为例实现右键菜单,图标会为被渲染为<i class="icon"></i>
          icon: "icon el-icon-top",
          onClick: () => {
            this.TopAddRowFun();
          },
        },
        {
          label: "删除会话",
          icon: "icon el-icon-delete",
          divided: true,
          onClick: () => {
            this.DeleteRowFun();
          },
        },
      ],
    };
  },

contextMenuData 数据中,label 是文字,onClick 是绑定的点击事件,icon 是图标,我这里用的element-ui 的图标,可以把icon的值设置为 icon el-icon-edit。第一个参数必填,固定为icon,第二个参数就是element-ui 图标库里对应的类名,divided 是分割线,默认是 false。

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-17 18:28:04       75 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-17 18:28:04       80 阅读
  3. 在Django里面运行非项目文件

    2024-07-17 18:28:04       64 阅读
  4. Python语言-面向对象

    2024-07-17 18:28:04       75 阅读

热门阅读

  1. Local Cache(一)Cache介绍

    2024-07-17 18:28:04       21 阅读
  2. Python题解Leetcode Hot100之技巧

    2024-07-17 18:28:04       23 阅读
  3. 生成式 AI 的发展方向,是 Chat 还是 Agent?

    2024-07-17 18:28:04       17 阅读
  4. 详解python基本语法

    2024-07-17 18:28:04       20 阅读
  5. I/O流的设计模式,分类,抽象类还有常用流

    2024-07-17 18:28:04       20 阅读
  6. Linux C++ 056-设计模式之迭代器模式

    2024-07-17 18:28:04       22 阅读
  7. 简谈设计模式之桥接模式

    2024-07-17 18:28:04       23 阅读
  8. Stream流

    Stream流

    2024-07-17 18:28:04      19 阅读
  9. r语言keras::tensorflow安装问题

    2024-07-17 18:28:04       21 阅读
  10. pycharm2020 相比pycarm2017更新内容

    2024-07-17 18:28:04       20 阅读
  11. springboot+js实现SSE消息推送

    2024-07-17 18:28:04       17 阅读