温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

vue怎么自定义右键菜单

发布时间:2022-04-11 10:37:41 来源:亿速云 阅读:964 作者:iii 栏目:开发技术

今天小编给大家分享一下vue怎么自定义右键菜单的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

vue怎么自定义右键菜单

1.在需要添加右键的页面,绑定contextmenu事件(阻止浏览器默认事件,添加自定义事件)

<div @contextmenu.prevent.native="openMenu($event)">
  ....
</div>

2.在页面编写右键菜单的内容

<ul v-show="visible" : class="contextmenu">
        <li @click="test">添加节点</li>
         <li @click="test">添加节点</li>
</ul>

3.在data()中定义需要的变量属性

data() {
    return {
      visible: false,
      top: 0,
      left: 0
    }
  }

4.创建监听事件,来触发关闭右键菜单的方法

watch: {
    visible(value) {
      if (value) {
        document.body.addEventListener('click', this.closeMenu)
      } else {
        document.body.removeEventListener('click', this.closeMenu)
      }
    }
  },

5.打开和关闭右键菜单的两个方法

//start
openMenu(e) {
  var x = e.pageX;
  var y = e.pageY;
  this.top = y;
  this.left = x;
  this.visible = true;//在这里控制右键菜单的打开
},
//close
closeMenu() {
  this.visible = false;
},

6.样式
 

.contextmenu {
  margin: 0;
  background: #fff;
  z-index: 3000;
  position: absolute;
  list-style-type: none;
  padding: 5px 0;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 400;
  color: #333;
  box-shadow: 2px 2px 3px 0 rgba(0, 0, 0, 0.3);
}

.contextmenu li {
  margin: 0;
  padding: 7px 16px;
  cursor: pointer;
}
.contextmenu li:hover {
  background: #eee;
}

以上就是“vue怎么自定义右键菜单”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI