首页 > 基础资料 博客日记
Javascript 、Vue —— 禁止鼠标右键点击事件!
2023-12-20 21:29:23基础资料围观725次
文章Javascript 、Vue —— 禁止鼠标右键点击事件!分享给大家,欢迎收藏Java资料网,专注分享技术知识
工作中碰见了奇葩的需求(见多了,也就不奇葩了哈哈)—— 用户让加上鼠标右键点击事件
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" 文本时,会显示一个自定义的菜单。右键菜单将会在用户点击其他地方或选择菜单项后隐藏。
运行效果图:
文章来源:https://blog.csdn.net/qq_53895518/article/details/132555933
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- springboot~3.x项目中使用集成测试
- Java测试类、工具类与JavaBean对比解析
- SpringBoot-日志
- springboot~http2的支持
- 解疑释惑 - 日志体系之 slf4j + logback 组合(一)
- Web server failed to start. Port 8080 was already in use. 端口被占用
- Springboot 项目配置多数据源
- 伙伴匹配系统(移动端 H5 网站(APP 风格)基于Spring Boot 后端 + Vue3 - 05
- 剑指offer-23、搜索⼆叉树的后序遍历序列
- 一个表示金额的数字是 100000000L,这是多少米?