当前位置: 代码网 > it编程>前端脚本>Vue.js > vue2项目实现自定义右键菜单,可添加图标、事件等方式

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

2024年05月26日 Vue.js 我要评论
通常浏览器都会有自己的右键菜单如下图的谷歌浏览器网页上的右键菜单:介绍一下如何在vue的项目中实现自定义菜单如下图所示 :1. 安装依赖包npm install vue-contextmenujs2.

通常浏览器都会有自己的右键菜单

如下图的谷歌浏览器网页上的右键菜单:

介绍一下如何在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',

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com