给vue标签绑定右击事件,显示自定义菜单

@contextmenu.prevent=‘fun()’
在给vue标签绑定右击事件的时候可能会没有效果,这时在外面套一层div,给div绑定右击事件就行了。
在这里插入图片描述
在这里插入图片描述
右击显示菜单:

 rightClick(event){ //定位自定义菜单的位置
            console.log(event.target.innerText)  //获取右击元素的text,可以识别当前右击的元素,方便后续做不同的逻辑操作
            this.rightClickPosition.show=true
            this.rightClickPosition.left=event.pageX+5
            this.rightClickPosition.top=event.pageY+5
}

但是菜单显示出来之后,点击元素之外的地方就应该隐藏菜单:监听 是否显示菜单的控制变量

watch:{
	'rightClickPosition.show':{
		handler(val){
                if (val) {//此时用户右击,变量为true,为body绑定点击事件来隐藏自定义菜单
                    document.body.addEventListener('click', this.closeContextMenu)
                } else {//此时变量为false,可能是默认值,也可能是用户点击了body其它地方
                    document.body.removeEventListener('click', this.closeContextMenu)
                }
        },
        deep:true
    }
}

closeContextMenu(){
            this.rightClickPosition.show=false
            this.rightClickPosition.left=0
            this.rightClickPosition.top=0
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值