Vue JS:右键单击事件指令
Posted
技术标签:
【中文标题】Vue JS:右键单击事件指令【英文标题】:Vue JS : right click event directive 【发布时间】:2016-08-05 23:55:15 【问题描述】:我知道这些 vue 事件处理程序:
@click : mouse left-click
@dblclick : mouse double click
检测右键单击的处理程序/指令可能是什么? 需要在 Vue Tree 视图中实现自定义上下文菜单。
【问题讨论】:
【参考方案1】:<button @contextmenu="handler($event)">r-click</button>
methods :
handler: function(e)
//do stuff
e.preventDefault();
@contextmenu
可以解决问题。 preventDefault
是为了避免显示默认的上下文菜单。
S更短,如评论中所示:
<button @contextmenu.prevent="handler">r-click</button>
现在prevent
修饰符负责防止默认行为。
编辑:要让它与 vue 组件一起使用,请添加 .native
事件修饰符。
<custom @contextmenu.native="handler"></custom>
【讨论】:
使用@contextmenu.prevent="..."
让 Vue 处理 preventDefault
【参考方案2】:
这里也是“自定义”词的答案 - 也就是 idea 如何捕捉正确的可点击元素的 ID
<html>
<head>
<style>
html, body, #app
margin: 0;
width: 100%;
height: 100%;
display: flex;
text-align: center;
align-items: center;
justify-content: center;
background-color: #343338;
font-family: Roboto, Tahoma, sans-serif;
.title
color: white;
display: block;
font-size: 25px;
.cls-context-menu
display:none;
position:absolute;
.cls-context-menu ul, #context-menu li
list-style:none;
margin:0; padding:0;
background:white;
.cls-context-menu border:solid 1px #CCC;
.cls-context-menu li
border-bottom:solid 1px #CCC;
display:block;
padding:5px 12px;
text-decoration:none;
color:blue;
.cls-context-menu li:hover
background: blue;
color: #FFF;
.cls-context-menu li:last-child border:none;
.context-menu-icon
top: 1px;
position: relative;
margin-right: 2px;
.cls-context-menu-item
cursor: pointer;
display:block;
padding:20px;
background:#ECECEC;
</style>
<!-- <link rel="stylesheet" type="text/css"
href="../../poc/right-click-vmenu/right-click-menu.css" /> -->
</head>
<body>
<template id="context-menu-item-template">
<li class="cls-context-menu-item">
<slot></slot>
</li>
</template>
<template id="context-menu-template">
<div id="div-context-menu" :nid="cid" class="cls-context-menu" style="left: 160px; top: 57px; display: none">
<ul>
<context-menu-item>
<a @click="addNewItem($event)"><img class="context-menu-icon" src="" >
add new </a>
</context-menu-item>
<context-menu-item>
<a @click="updateItem($event)"><img class="context-menu-icon" src="" >
edit </a>
</context-menu-item>
<context-menu-item>
<a @click="removeItem($event)"><img class="context-menu-icon" src="" >
remove</a>
</context-menu-item>
</ul>
</div>
</template>
<div id="app" @click="hideContextMenu()" @contextmenu = "showContextMenu($event)">
<div>
<h3 id="title-1" class="title">Num-01 Click with right-a on body</h3>
<h3 id="title-2" class="title">Num-02 Click with right-a on body</h3>
</div>
<context-menu></context-menu>
</div>
<div id="js_libs">
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script src="https://unpkg.com/vue@2.5.3/dist/vue.js"></script>
<script src="https://unpkg.com/vuex@3.0.1/dist/vuex.js"></script>
</div>
<script>
Vue.component('context-menu-item',
template: '#context-menu-item-template',
props:
icon: ''
);
Vue.component('context-menu',
template: '#context-menu-template'
, props:
icon: ''
, nid: null
, data()
return
cid: null
, methods:
addNewItem: function (e)
var itemId = e.target.parentElement.parentElement.parentElement.cid
var msg = "UPDATE clicked for item-id : " + itemId
console.log ( msg ) ; alert ( msg ) ;
, updateItem: function (e)
var itemId = e.target.parentElement.parentElement.parentElement.cid
var msg = "UPDATE clicked for item-id : " + itemId
console.log ( msg ) ; alert ( msg ) ;
, removeItem: function (e)
var itemId = e.target.parentElement.parentElement.parentElement.cid
var msg = "REMOVE clicked for item-id : " + itemId
console.log ( msg ) ; alert ( msg ) ;
);
var vm = new Vue(
el: '#app'
, methods:
showContextMenu: function (e)
if ( e.target.className.startsWith("title") )
e.preventDefault();
var menu = document.getElementById("div-context-menu");
menu.style.left = e.pageX + 'px'
menu.style.top = e.pageY + 'px'
menu.style.display = 'block'
menu.cid = e.target.id.replace(/title-/,"")
console.log ( "cid")
console.log ( menu.cid )
, hideContextMenu: function ()
document.getElementById("div-context-menu").style.display = "none"
);
</script>
</body>
</html>
【讨论】:
以上是关于Vue JS:右键单击事件指令的主要内容,如果未能解决你的问题,请参考以下文章