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 相关文章推荐
js 获取Listbox选择的值的代码
Apr 15 Javascript
页面加载完成后再执行JS的jquery写法以及区别说明
Feb 22 Javascript
jQuery中height()方法用法实例
Dec 24 Javascript
jQuery中remove()方法用法实例
Dec 25 Javascript
jquery实现可关闭的倒计时广告特效代码
Sep 02 Javascript
JS实用的带停顿的逐行文本循环滚动效果实例
Nov 23 Javascript
AngularJS 限定$scope的范围实例详解
Jun 23 Javascript
element-ui 上传图片后清空图片显示的实例
Sep 04 Javascript
自己动手封装一个React Native多级联动
Sep 19 Javascript
微信小程序制作表格的方法
Feb 14 Javascript
react写一个select组件的实现代码
Apr 03 Javascript
javascript/jquery实现点击触发事件的方法分析
Nov 11 jQuery
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
为什么夜间收到的中波电台比白天多
2021/03/01 无线电
深入理解用mysql_fetch_row()以数组的形式返回查询结果
2013/06/05 PHP
php简单实现多字节字符串翻转的方法
2015/03/31 PHP
PHP内存缓存功能memcached示例
2016/10/19 PHP
php实现大文件断点续传下载实例代码
2019/10/01 PHP
Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例
2019/10/11 PHP
Laravel 5.5 实现禁用用户注册示例
2019/10/24 PHP
Javascript无参数和有参数类继承问题解决方法
2015/03/02 Javascript
详解JavaScript编程中正则表达式的使用
2015/10/25 Javascript
JavaScript驾驭网页-DOM
2016/03/24 Javascript
Jq通过td获取同行其它列td的方法
2016/10/05 Javascript
移动端点击态处理的三种实现方式
2017/01/12 Javascript
gulp加批处理(.bat)实现ng多应用一键自动化构建
2017/02/16 Javascript
一道面试题引发的对javascript类型转换的思考
2017/03/06 Javascript
bootstrap paginator分页前后台用法示例
2017/06/17 Javascript
Node解决简单重复问题系列之Excel内容的获取
2018/01/02 Javascript
ES6的解构赋值实例详解
2019/05/06 Javascript
Vue+Django项目部署详解
2019/05/30 Javascript
[03:32]2014DOTA2西雅图邀请赛 CIS外卡赛赛前black专访
2014/07/09 DOTA
Python(Tornado)模拟登录小米抢手机
2013/11/12 Python
python显示天气预报
2014/03/02 Python
详解python3实现的web端json通信协议
2016/12/29 Python
Python 离线工作环境搭建的方法步骤
2019/07/29 Python
CSS3提交意见输入框样式代码
2014/10/30 HTML / CSS
美国最古老的精致书写工具制造商:A.T. Cross(高仕)
2018/01/30 全球购物
德国在线购买葡萄酒网站:Geile Weine
2019/09/24 全球购物
伦敦鲜花递送:Flower Station
2021/02/03 全球购物
拉丁舞学习者的自我评价
2013/10/27 职场文书
小学一年级学生评语
2014/04/22 职场文书
捐书活动总结
2014/05/04 职场文书
土地转让协议书
2014/09/27 职场文书
通报表扬范文
2015/01/17 职场文书
年度考核个人总结
2015/03/06 职场文书
python - asyncio异步编程
2021/04/06 Python
Redis实现一个账号只能登录一个设备
2022/04/19 Redis
webpack介绍使用配置教程详解webpack介绍和使用
2022/06/25 Javascript