900字范文,内容丰富有趣,生活中的好帮手!
900字范文 > Javascript Vue —— 禁止鼠标右键点击事件!

Javascript Vue —— 禁止鼠标右键点击事件!

时间:2023-10-04 23:30:50

相关推荐

Javascript  Vue —— 禁止鼠标右键点击事件!

工作中碰见了奇葩的需求(见多了,也就不奇葩了哈哈)—— 用户让加上鼠标右键点击事件

1、oncontextmenu 事件

定义:oncontextmenu 事件在元素中用户右击鼠标时触发并打开上下文菜单。

HTML :

<elementoncontextmenu="myScript">

JavaScript :

object.oncontextmenu=function(){myScript};

JavaScript 中, 使用 addEventListener() 方法:

object.addEventListener("contextmenu",myScript);

注意:Internet Explorer 8 及更早 IE 浏览器版本不支持addEventListener()。

2、JS实例

添加右击事件 阻止默认行为—— oncontextmenu /contextmenu

document.addEventListener("oncontextmenu",function(evt){console.log("右键单击,自定义右键菜单")evt.preventDefault()})

注意:所有浏览器都支持 oncontextmenu 事件,contextmenu元素只有 Firefox 浏览器支持。

3、Vue实例

在 Vue.js 中,要实现右键点击事件,可以使用 Vue 的contextmenu指令来监听上下文菜单事件。这个指令会在用户右键点击元素时触发。以下是一个示例:

HTML :

<div @contextmenu="showContextMenu" class="right-clickable">Right-click me<div v-if="contextMenuVisible" class="context-menu"><!-- 右键菜单的内容 --><ul><li @click="menuItemClicked('Option 1')">Option 1</li><li @click="menuItemClicked('Option 2')">Option 2</li><li @click="menuItemClicked('Option 3')">Option 3</li></ul></div></div>

JavaScript :

export default {data() {return {contextMenuVisible: false,contextMenuPosition: { x: 0, y: 0 }};},methods: {showContextMenu(event) {// 阻止默认右键菜单event.preventDefault();// 获取右键点击的位置this.contextMenuPosition.x = event.clientX;this.contextMenuPosition.y = event.clientY;// 显示右键菜单this.contextMenuVisible = true;},hideContextMenu() {// 隐藏右键菜单this.contextMenuVisible = false;},menuItemClicked(option) {// 处理菜单选项点击事件console.log('Clicked:', option);this.hideContextMenu();}},mounted() {// 监听点击页面其他部分,以隐藏右键菜单window.addEventListener('click', this.hideContextMenu);},beforeDestroy() {// 移除监听器,以防止内存泄漏window.removeEventListener('click', this.hideContextMenu);}};

CSS:

.right-clickable {position: relative;}.context-menu {position: absolute;background-color: #fff;border: 1px solid #ccc;padding: 5px;box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1);z-index: 1000;}.context-menu ul {list-style: none;padding: 0;margin: 0;}.context-menu li {padding: 5px 10px;cursor: pointer;}

这是一个简单的示例,展示了如何使用contextmenu指令来实现右键点击事件和弹出自定义的右键菜单。在这个示例中,当用户右键点击 "Right-click me" 文本时,会显示一个自定义的菜单。右键菜单将会在用户点击其他地方或选择菜单项后隐藏。

运行效果图:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。