js oncontextmenu事件使用详解

发布时间 - 2026-01-11 00:22:20    点击率:

定义和使用

oncontextmenu 事件在元素中用户右击鼠标时触发并打开上下文菜单。
注意:所有浏览器都支持 oncontextmenu 事件, contextmenu 元素只有 Firefox 浏览器支持。

实例

当用户在 <div> 元素 上右击鼠标时执行 JavaScript :

<div oncontextmenu="myFunction()" contextmenu="mymenu">

用oncontextmenu事件单禁用右键菜单

onconTextmenu=window.event.returnValue=false;右键菜单禁用,用这个可以禁止复制。

在<body>中加入属性代码:

<script>
 window.document.oncontextmenu = function(){ 
//alert('请不要点击鼠标右键!');
return false;
} 
</script>

oncontextmenu="return false"

onselectstart="return false" 禁止选中网页上的内容

oncopy="return false" 防复制用户在网页上选中的内容

防止用户另存网页:

利用<noscript><iframe src=*.html></iframe></noscript>标签,能防止网页的直接另存,但不能防止网页被人使用工具下载

*为通配符。

例1:

<html>
<head>
<title>OnContextMenu事件</title>
<script language="JavaScript">
<!--
function uFunction()
{   
  document.all.infoDiv.innerHTML='你按下了鼠标右键,但是右键菜单不能 显示!';
}
function uFunction2()
{  
  document.all.infoDiv.innerHTML='你按下了Ctrl+鼠标右键,可以 显示右键菜单。';
}
//-->
</script>
</head>
<body oncontextmenu="if(!event.ctrlKey){uFunction();return false}else{uFunction2()}">
  <div id="infoDiv">你按下了鼠标右键,但是右键菜单不能 显示!<br>你按下了Ctrl+鼠标右键,可以显示右键菜单。
  </div>
</body>
</html>

例2:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
  <title>利用OnMousedown和OnContextmenu为表格添加鼠标左中右键单击的处理</title>
  <script type="text/javascript">
    var keyArray = new Array(
      new Array(0, "右键"),
      new Array(1, "左键"),
      new Array(2, "右键"), // 测试在IE7中按右键是2,在Maxthon2.0正式版中是0
      new Array(3, "左键右键同时按"),//在IE7中我测试捕获不到,慎用
      new Array(4, "中键")
      //测试同时按两个键更多的表示
      //new Array(6, "中键右键同时按")
    );
    function Click()
    {
      var message = GetKeyMessage(event.button);
      alert(message);
      if (event.button == 2 || event.button == 0) //按右键,// 测试在IE7中按右键是2,在Maxthon2.0正式版中是0
       {
        //处理代码
      }
    }
    function GetKeyMessage(button)
    {
      for (var i = 0; i < keyArray.length; i++)
      {
        if (keyArray[i][0] == button)
        {
          return keyArray[i][1] + ", event.button = " + button;
        }
      }
       return "未知组合键, event.button = " + button;
    }
  </script>
</head>
<body>
<table cellpadding="0" cellspacing="0" border="1">
<tr>
  <!--oncontextmenu="return false"屏蔽快捷菜单-->
  <td oncontextmenu="return false" onmousedown="Click()">请分别用左键、右键、中键、左键右键组合点这里测试</td>
</tr>
<tr>
  <td>这个表格没有处理,点这里没反应</td>
</tr>
</table>
</body>
</html>


# js  # oncontextmenu  # 右键  # 右键菜单  # 鼠标右键  # 按下  # 左键  # 鼠标  # 点这里  # 右击  # 另存  # 版中  # 被人  # 请不要  # 工具下载  # 单击  # 点击鼠标  # 禁止复制  # 组合键  # document  # return  # contextmenu 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 宙斯浏览器视频悬浮窗怎么开启 边看视频边操作其他应用教程  Laravel storage目录权限问题_Laravel文件写入权限设置  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  详解阿里云nginx服务器多站点的配置  如何在IIS服务器上快速部署高效网站?  再谈Python中的字符串与字符编码(推荐)  如何在景安云服务器上绑定域名并配置虚拟主机?  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?  中山网站制作网页,中山新生登记系统登记流程?  html文件怎么打开证书错误_https协议的html打开提示不安全【指南】  详解vue.js组件化开发实践  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  详解Android——蓝牙技术 带你实现终端间数据传输  焦点电影公司作品,电影焦点结局是什么?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  如何快速搭建高效服务器建站系统?  谷歌Google入口永久地址_Google搜索引擎官网首页永久入口  如何在腾讯云服务器上快速搭建个人网站?  Java垃圾回收器的方法和原理总结  JS去除重复并统计数量的实现方法  详解jQuery中的事件  如何在HTML表单中获取用户输入并用JavaScript动态控制复利计算循环  Python制作简易注册登录系统  WordPress 子目录安装中正确处理脚本路径的完整指南  佛山企业网站制作公司有哪些,沟通100网上服务官网?  打开php文件提示内存不足_怎么调整php内存限制【解决方案】  如何做网站制作流程,*游戏网站怎么搭建?  如何在建站之星绑定自定义域名?  php在windows下怎么调试_phpwindows环境调试操作说明【操作】  nginx修改上传文件大小限制的方法  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  网站制作报价单模板图片,小松挖机官方网站报价?  如何彻底卸载建站之星软件?  实例解析Array和String方法  PHP 500报错的快速解决方法  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  Laravel如何配置和使用队列处理异步任务_Laravel队列驱动与任务分发实例  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  如何快速搭建二级域名独立网站?  Python自然语言搜索引擎项目教程_倒排索引查询优化案例  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  如何为不同团队 ID 动态生成多个非值班状态按钮