必威体育Betway必威体育官网
当前位置:首页 > IT技术

js oncontextmenu事件使用详解

时间:2019-10-01 03:15:41来源:IT技术作者:seo实验室小编阅读:54次「手机版」
 

oncontextmenu

定义和使用

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

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

实例

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

<p οncοntextmenu="myFunction()" contextmenu="mymenu">
用oncontextmenu事件单禁用右键菜单

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

在<body>中加入属性代码

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

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

οncοpy="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 οncοntextmenu="if(!event.ctrlKey){uFunction();return false}else{uFunction2()}">
  <p id="infoDiv">你按下了鼠标右键,但是右键菜单不能 显示!<br>你按下了Ctrl+鼠标右键,可以显示右键菜单。
  </p>
</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>
  <!--οncοntextmenu="return false"屏蔽快捷菜单-->
  <td οncοntextmenu="return false" οnmοusedοwn="Click()">请分别用左键、右键、中键、左键右键组合点这里测试</td>
</tr>
<tr>
  <td>这个表格没有处理,点这里没反应</td>
</tr>
</table>
</body>
</html>
 

相关阅读

跌掉一个星巴克后,Facebook泄密事件告诉了我们什么?

Facebook数据泄密事件发生后,全球大为震惊,而只不过是过去数年来众多互联网泄密事件一个小小的案例。那么数据泄密为何会屡屡发生?对

windows事件查看器

打开方式:右键左下角的windows ,然后按v                         或者 Windows+R 后 输入eventvwr.msc 也行 主要

论海运女事件带来的强大流量

关键字搜索次数独立访客IP新独立访客历史查看引擎海运女照片下载1159210188932710182历史点击查看引擎名称比例(搜索次数)百度 86

朋友圈刷屏的“圣诞帽”是意外造就的“骗局”?5000字还

“圣诞帽”的刷屏确实可以说是天时地利人和了,而且这个看来似乎简单的活动,也并不是那么容易成功复制的,所以千千试着分析一下我们可

中兴禁购事件给中国企业的反思

两年前的4月19日,习近平总书记提出,互联网核心技术是我们最大的&ldquo;命门&rdquo;,核心技术受制于人是最大的隐患。直到今天,这一预

分享到:

栏目导航

推荐阅读

热门阅读