# vue3-context-menu **Repository Path**: hcheng_pan/vue3-context-menu ## Basic Information - **Project Name**: vue3-context-menu - **Description**: 一个简洁美观简单的Vue3右键菜单组件 - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: main - **Homepage**: https://imengyu.top/pages/vue3-context-menu-docs/ - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 3 - **Created**: 2023-11-14 - **Last Updated**: 2023-11-14 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # vue3-context-menu 一个使用 Vue3 制作的简洁美观简单的右键菜单组件 ![截图](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/first.png) --- ## 特性 * 简洁易用,体积小 * 提供组件模式和函数模式,调用方便 * 提供多个菜单主题供您使用 * 可自定义 ### 用法 ``` npm install -save @imengyu/vue3-context-menu ``` 然后在 main.ts 中导入: ```js import '@imengyu/vue3-context-menu/lib/vue3-context-menu.css' import ContextMenu from '@imengyu/vue3-context-menu' createApp(App).use(ContextMenu) ``` 然后你就可以在 vue 文件中使用菜单了: ```js import ContextMenu from '@imengyu/vue3-context-menu' onContextMenu(e : MouseEvent) { //prevent the browser's default menu e.preventDefault(); //show your menu ContextMenu.showContextMenu({ x: e.x, y: e.y, items: [ { label: "A menu item", onClick: () => { alert("You click a menu item"); } }, { label: "A submenu", children: [ { label: "Item1" }, { label: "Item2" }, { label: "Item3" }, ] }, ] }); } ``` 关于详细的用法,请参考文档。 ## 文档 [查看文档](https://imengyu.top/pages/vue3-context-menu-docs/) [查看在线演示](https://imengyu.top/pages/vue3-context-menu-demo/) ## 开发 ```shell git clone git@github.com:imengyu/vue3-context-menu.git cd vue3-context-menu npm install npm serve ``` ## 已有主题 |theme|explain|example image| |--|--|--| |`default`|Default theme|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-default.jpg)| |`default dark`|Default theme with dark|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-default-dark.jpg)| |`flat`|Simple flat theme|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-flat.jpg)| |`flat dark`|Simple flat theme with dark|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-flat-dark.jpg)| |`win10`|Win10 like theme|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-win10.jpg)| |`win10 dark`|Win10 like theme with dark|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-win10-dark.jpg)| |`mac`|Mac like theme|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-mac.jpg)| |`mac dark`|Mac like theme with dark|![example-default-dark.jpg](https://raw.githubusercontent.com/imengyu/vue3-context-menu/main/screenshot/example-mac-dark.jpg)| ## License [MIT](./LICENSE)