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

用户让加上鼠标右键点击事件

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" 文本时,会显示一个自定义的菜单。右键菜单将会在用户点击其他地方或选择菜单项后隐藏。

运行效果图:

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Vue中实现自定义的鼠标右键菜单,你可以借助第三方插件或者自己编写代码来实现。下面是一个使用第三方插件 `vue-contextmenu` 的示例: 首先,安装 `vue-contextmenu` 插件: ```shell npm install vue-contextmenu ``` 然后,在你的Vue项目中,导入并注册 `vue-contextmenu` 插件: ```javascript import VueContextmenu from 'vue-contextmenu'; Vue.use(VueContextmenu); ``` 接下来,在需要添加右键菜单的元素上使用 `v-contextmenu` 指令,并绑定一个方法来定义菜单的内容和行为: ```html <template> <div> <div v-contextmenu="contextMenu"> Right-click me! </div> </div> </template> <script> export default { data() { return { contextMenu: [ { text: '菜单项1', action: 'menuItem1' }, { text: '菜单项2', action: 'menuItem2' }, { text: '菜单项3', action: 'menuItem3' } ] }; }, methods: { menuItem1() { console.log('执行菜单项1的操作'); }, menuItem2() { console.log('执行菜单项2的操作'); }, menuItem3() { console.log('执行菜单项3的操作'); } } }; </script> ``` 在这个例子中,`contextMenu` 数组定义了右键菜单的内容,每个菜单项都有一个 `text` 属性用于显示菜单项的文本,以及一个 `action` 属性用于定义菜单项被点击时要执行的方法。 运行项目后,当你在指定的元素上右键点击时,就会弹出自定义的右键菜单,并执行相应的方法。 除了使用第三方插件外,你也可以根据需求自己编写代码来实现自定义的鼠标右键菜单。这需要使用原生JavaScript事件来捕获右键点击事件,并自定义菜单的样式和行为。 希望对你有所帮助!如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值