vue 右键菜单的实现

最近一个项目,选中某些文本,然后右键进行一些操作,使用了vue-contextmenujs插件

  1. 安装vue-contextmenujs

    npm install vue-contextmenujs

  2. mian.js中引用该组件

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

  3. 页面中使用

4.判断是否在该文本区域内

复制代码
 rightClick(event) {
      console.log("点击了右键", event);
      this.chapterText = ""; // 先清空,chapterText 保存选中文本
      let sel = window.getSelection
        ? window.getSelection()
        : document.selection.createRange();
      let text = sel.toString();
      if (!text) {
        return false;
      }

      let divId = "bodyContainer";
      if (sel.getRangeAt) {

        var range = sel.getRangeAt(0);
        var ancestor = range.commonAncestorContainer;
        while (
          ancestor.id != divId && // Check id, class or otherwise
          ancestor.parentElement != null
        ) {
          ancestor = ancestor.parentElement;
        }

        if (ancestor.id == divId) {
          // Selection is within the editor.
          console.log("在div内");
          this.chapterText = window.getSelection().toString();
          this.$contextmenu({
            items: this.rightMenuData,
            event, // 鼠标事件信息
            customClass: "custom-class", // 自定义菜单 class
            zIndex: 3, // 菜单样式 z-index
            minWidth: 150, // 主菜单最小宽度
          });
        } else {
          console.log("不在div内");
          return false;
        }
      } else {
        //
        return false;
      }

      return false;
    },

5.菜单

复制代码
 rightMenuData: [
        {
          label: "翻译",
          onClick: () => {
            this.handleTranslate();
          },
        },
           ....
        },
      ],
相关推荐
qq_5470261795 小时前
Flowable 工作流引擎
java·服务器·前端
刘逸潇20055 小时前
CSS基础语法
前端·css
Sheldon一蓑烟雨任平生6 小时前
Vue3 插件(可选独立模块复用)
vue.js·vue3·插件·vue3 插件·可选独立模块·插件使用方式·插件中的依赖注入
吃饺子不吃馅6 小时前
[开源] 从零到一打造在线 PPT 编辑器:React + Zustand + Zundo
前端·svg·图形学
小马哥编程7 小时前
【软考架构】案例分析-Web应用设计(应用服务器概念)
前端·架构
鱼与宇7 小时前
苍穹外卖-VUE
前端·javascript·vue.js
啃火龙果的兔子7 小时前
前端直接渲染Markdown
前端
z-robot7 小时前
Nginx 配置代理
前端
用户47949283569157 小时前
Safari 中文输入法的诡异 Bug:为什么输入 @ 会变成 @@? ## 开头 做 @ 提及功能的时候,测试同学用 Safari 测出了个奇怪的问题
前端·javascript·浏览器
没有故事、有酒7 小时前
Ajax介绍
前端·ajax·okhttp