加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营 > 正文

Vue+element-ui添加自定义右键菜单的方法示例

发布时间:2020-12-11 12:30:00 所属栏目:运营 来源:网络整理
导读:这篇文章首要给各人先容了关于Vue+element-ui添加自界说右键菜单的相干资料,文中通过示例代码先容的很是具体,对各人的进修可能事变具有必然的参考进修代价,需

  短视频,自媒体,达人种草一站处事

这篇文章首要给各人先容了关于Vue+element-ui添加自界说右键菜单的相干资料,文中通过示例代码先容的很是具体,对各人的进修可能事变具有必然的参考进修代价,必要的伴侣们下面跟着小编来一路进修进修吧

1、在所编辑的页面,必要添加右键菜单的元素,绑定contextmenu变乱

<template>
<el-button size="medium" @contextmenu.prevent.native="openMenu($event)">
......
</template>

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

<ul v-show="visible" :style="{left:left+'px',top:top+'px'}">
<li>上移一层</li>
<li>下移一层</li>
</ul>

3、在data()中界说必要的变量属性

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

4、调查visible的变革,来触发封锁右键菜单,挪用封锁菜单的要领

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

5、在method中界说打开右键菜单和封锁右键菜单的两个要领

openMenu(e) {
const menuMinWidth = 105
const offsetLeft = this.$el.getBoundingClientRect().left // container margin left
const offsetWidth = this.$el.offsetWidth // container width
const maxLeft = offsetWidth - menuMinWidth // left boundary
const left = e.clientX - offsetLeft // 15: margin right

if (left > maxLeft) {
this.left = maxLeft
} else {
this.left = left
}

this.top = e.clientY - 60 // fix 位置bug
this.visible = true
},
closeMenu() {
this.visible = false
}

6、在style中写右键菜单的样式

.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);
li {
margin: 0;
padding: 7px 16px;
cursor: pointer;
&:hover {
background: #eee;
}
}
}

留意:.native修饰符对vue组件元素监听原闹变乱有用,对原生的html元素行使,反而没有结果。

到此这篇关于Vue+element-ui添加自界说右键菜单的文章就先容到这了,更多相干Vue+element-ui添加自界说右键菜单内容请搜刮剧本之家早年的文章或继承赏识下面的相干文章但愿各人往后多多支持剧本之家!

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读