Javascript 、Vue禁止鼠标右键点击事件实例
作者:爱吃果蔬的猫
这篇文章主要给大家介绍了关于Javascript 、Vue禁止鼠标右键点击事件的相关资料,禁止右键的原理是通过JavaScript阻止浏览器右键事件的默认行为,从而达到禁止右键的效果,文中通过代码介绍的非常详细,需要的朋友可以参考下
工作中碰见了奇葩的需求(见多了,也就不奇葩了哈哈)—— 用户让加上鼠标右键点击事件
1、oncontextmenu 事件
定义 :oncontextmenu 事件在元素中用户右击鼠标时触发并打开上下文菜单。
HTML :
<element oncontextmenu="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" 文本时,会显示一个自定义的菜单。右键菜单将会在用户点击其他地方或选择菜单项后隐藏。
运行效果图:
总结
到此这篇关于Javascript 、Vue禁止鼠标右键点击事件的文章就介绍到这了,更多相关Js Vue禁止鼠标右键点击事件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!