vue2项目实现自定义右键菜单, 可添加图标、事件等

通常浏览器都会有自己的右键菜单,如下图的谷歌浏览器网页上的右键菜单:

下面介绍一下如何在vue的项目中实现自定义菜单,如下图所示 :

1. 安装依赖包

npm install vue-contextmenujs

2. 在main.js中引用

import Contextmenu from 'vue-contextmenujs';
Vue.use(Contextmenu);

3. 在需要实现自定义右键的元素上加上 @contextmenu.prevent="onContextmenu"

<div class="CodeMirror-Contain" @contextmenu.prevent="onContextmenu">
    <textarea ref="codeMirror"></textarea>
</div>

4. methods中添加方法

// 鼠标右键事件
onContextmenu(event) {
    this.$contextmenu({
        items: this.contextMenuData,
        event, // 鼠标事件信息
        customClass: 'custom-class', // 自定义菜单 class
        zIndex: 3, // 菜单样式 z-index
        minWidth: 230 // 主菜单最小宽度
    });
    return false;
},

5.  contextMenuData 的数据如下

this.contextMenuData = [
    {
        label: '运行',
        icon: 'iconfont icon-zhihang',
        onClick: () => {
            this.onRunCode();
        }
    },
    {
        label: '运行',
        icon: 'iconfont icon-sql_exec_new',
        onClick: () => {
            this.onRunCodeNewTab();
        }
    },
    {
        label: '收藏',
        icon: 'iconfont icon-baocun1',
        divided: true,
        onClick: () => {
            this.onCommitOrder();
        }
    },
    {
        label: '格式化',
        icon: 'iconfont icon-geshihua1',
        onClick: () => {
            this.onFormatSQL();
        }
    }
];

contextMenuData中,label是文字,onClick是绑定的点击事件,icon是图标,我这里用的阿里的iconfont,如果想使用ElementUI的图标,可以把icon的值设置为 icon el-icon-edit。第一个参数必填,固定为icon,第二个参数就是ElementUI图标库里对应的类名。

icon: 'icon el-icon-edit',

 如果帮助到您了,可以留下一个赞👍告诉我  

  • 6
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序猿小野

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值