js oncontextmenu事件使用详解


Posted in Javascript onMarch 25, 2017

定义和使用

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>
Javascript 相关文章推荐
Javascript实现返回上一页面并刷新的小例子
Dec 11 Javascript
jQuery+easyui中的combobox实现下拉框特效
Feb 27 Javascript
JS实现FLASH幻灯片图片切换效果的方法
Mar 04 Javascript
JavaScript中的small()方法使用详解
Jun 08 Javascript
JavaScript中的cacheStorage使用详解
Jul 29 Javascript
js获取Html元素的实际宽度高度的方法
May 19 Javascript
详解vuelidate 对于vueJs2.0的验证解决方案
Mar 09 Javascript
JS实现多级菜单中当前菜单不随页面跳转样式而发生变化
May 30 Javascript
Vue不能检测到Object/Array更新的情况的解决
Jun 26 Javascript
微信小程序bindinput与bindsubmit的区别实例分析
Apr 17 Javascript
vue实现图片上传预览功能
Dec 23 Javascript
详解vite2.0配置学习(typescript版本)
Feb 25 Javascript
js 函数式编程学习笔记
Mar 25 #Javascript
CodeMirror js代码加亮使用总结
Mar 25 #Javascript
js 去掉字符串前后空格实现代码集合
Mar 25 #Javascript
在js中做数字字符串补0(js补零)
Mar 25 #Javascript
JavaScript 字符串数字左补位,右补位,取固定长度,截位扩展函数代码
Mar 25 #Javascript
JS去掉字符串前后空格或去掉所有空格的用法
Mar 25 #Javascript
javascript作用域链与执行环境详解
Mar 25 #Javascript
You might like
ThinkPHP5.0框架使用build 自动生成模块操作示例
2019/04/11 PHP
用JavaScript对JSON进行模式匹配 (Part 2 - 实现)
2010/07/17 Javascript
js获取当前日期时间及其它操作汇总
2015/04/17 Javascript
js实现简洁大方的二级下拉菜单效果代码
2015/09/01 Javascript
javascript学习总结之js使用技巧
2015/09/02 Javascript
轻松学习jQuery插件EasyUI EasyUI实现拖动基本操作
2015/11/30 Javascript
jQuery图片渐变特效的简单实现
2016/06/25 Javascript
javascript设计模式Constructor(构造器)模式
2016/08/19 Javascript
简述jQuery Easyui一些用法
2017/08/01 jQuery
JQuery 选择器、DOM节点操作练习实例
2017/09/28 jQuery
详解使用React进行组件库开发
2018/02/06 Javascript
微信小程序实现无限滚动列表
2020/05/29 Javascript
vue+SSM实现验证码功能
2018/12/07 Javascript
小程序server请求微信服务器超时的解决方法
2019/05/21 Javascript
Vue.js 中的实用工具方法【推荐】
2019/07/04 Javascript
如何通过Proxy实现JSBridge模块化封装
2020/10/22 Javascript
Python获取当前时间的方法
2014/01/14 Python
Python实现telnet服务器的方法
2015/07/10 Python
python多线程方式执行多个bat代码
2016/06/07 Python
Win7 64位下python3.6.5安装配置图文教程
2020/10/27 Python
python对于requests的封装方法详解
2019/01/03 Python
python3实现小球转动抽奖小游戏
2020/04/15 Python
django之自定义软删除Model的方法
2019/08/14 Python
python输出第n个默尼森数的实现示例
2020/03/08 Python
将 Ubuntu 16 和 18 上的 python 升级到最新 python3.8 的方法教程
2020/03/11 Python
python高阶函数map()和reduce()实例解析
2020/03/16 Python
使用pandas库对csv文件进行筛选保存
2020/05/25 Python
ubuntu16.04升级Python3.5到Python3.7的方法步骤
2020/08/20 Python
解决pycharm导入numpy包的和使用时报错:RuntimeError: The current Numpy installation (‘D:\\python3.6\\lib\\site-packa的问题
2020/12/08 Python
请解释接口的显式实现有什么意义
2012/05/26 面试题
医院护理人员的自我评价分享
2013/10/04 职场文书
音乐器材管理制度
2014/01/31 职场文书
2014办公室年度工作总结
2014/12/09 职场文书
青年文明号汇报材料
2014/12/23 职场文书
民间借贷纠纷案件代理词
2015/05/26 职场文书
如何用Python搭建gRPC服务
2021/06/30 Python