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":
html 复制代码
<div style="width:100vw;height:100vh" @contextmenu.prevent="onContextmenu">
	<div>右键</div>
</div>
4.2 在methods中添加方法:
js 复制代码
  // 鼠标右键事件
  onContextmenu(event) {
    this.$contextmenu({
        items: this.contextMenuData,
        event, // 鼠标事件信息
        customClass: 'custom-class', // 自定义菜单 class
        zIndex: 3, // 菜单样式 z-index
        minWidth: 230 // 主菜单最小宽度
    });
    return false;
  },
4.3 contextMenuData 的数据如下:
js 复制代码
 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。

相关推荐
m0_748255268 分钟前
easyExcel导出大数据量EXCEL文件,前端实现进度条或者遮罩层
前端·excel
长风清留扬28 分钟前
小程序毕业设计-音乐播放器+源码(可播放)下载即用
javascript·小程序·毕业设计·课程设计·毕设·音乐播放器
web1478621072341 分钟前
C# .Net Web 路由相关配置
前端·c#·.net
m0_7482478042 分钟前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter
飞的肖1 小时前
前端使用 Element Plus架构vue3.0实现图片拖拉拽,后等比压缩,上传到Spring Boot后端
前端·spring boot·架构
青灯文案11 小时前
前端 HTTP 请求由 Nginx 反向代理和 API 网关到后端服务的流程
前端·nginx·http
m0_748254881 小时前
DataX3.0+DataX-Web部署分布式可视化ETL系统
前端·分布式·etl
ZJ_.1 小时前
WPSJS:让 WPS 办公与 JavaScript 完美联动
开发语言·前端·javascript·vscode·ecmascript·wps
GIS开发特训营1 小时前
Vue零基础教程|从前端框架到GIS开发系列课程(七)响应式系统介绍
前端·vue.js·前端框架·gis开发·webgis·三维gis
Cachel wood2 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架