当前位置: 移动技术网 > IT编程>开发语言>JavaScript > jquery实现人性化的有选择性禁用鼠标右键

jquery实现人性化的有选择性禁用鼠标右键

2019年03月25日  | 移动技术网IT编程  | 我要评论

使用比较暴力的手段禁用鼠标右键是不人性化的,所以最好还是有选择性的禁用鼠标右键。

代码实例如下:

<!doctype html> <html> 
<head> 
<meta charset="utf-8"> 
<meta name="author" content="https://www.45it.com/" /> 
<title>博客园</title> 
<style type="text/css">
html,body{height:100%}
p{
width:150px;
height:50px;
background:#ccc;
}
</style>
<script type="text/javascript" src="mytest/jquery/jquery-1.8.3.js"></script>
<script type="text/javascript"> 
$(document).ready(function(){
function jquery_istagname(ev,arr){
ev=$.event.fix(ev);
var target=ev.target||ev.srcelement;
if(arr&&$.inarray(target.tagname.tostring().touppercase(),arr)==-1){
return false;
}
return true;
}

$(document).bind("contextmenu",function(ev){
if(!jquery_istagname(ev,['input','textarea'])){
ev.preventdefault();
return false;
}
return true;
})
})
</script> 
</head> 
<body>
<p id="thep"></p> 
<textarea></textarea>
</body> 
</html>

上面的代码实现了我们的要求,下面对代码的实现过程做一下介绍。

代码注释:

1.$(document).ready(function(){}),当文本结构完全加载完毕再去执行函数中的代码。
2.function jquery_istagname(ev,arr){},此函数可以判断元素是否在可以使用右键菜单之列,第一个参数是事件对象,第二个参数是一个数组,数组元素是可以使用右键菜单的标签名称。
3.ev=$.event.fix(ev),实现事件对象在各个的兼容性,fix()函数是jquery内部使用的,当然也可以这么用。
4.var target=ev.target||ev.srcelement,获取事件源对象。
5.if(arr&&$.inarray(target.tagname.tostring().touppercase(),arr)==-1){return false;},判断指定的标签元素是否在数组中,如果数组中没有指定的标签,那么就返回false。
6.return true,返回true。
8.$(document).bind("contextmenu",function(ev){}),为document文档注册contextmenu事件处理函数。
9.if(!jquery_istagname(ev,['input','textarea'])){
ev.preventdefault();
return false;
}
如果如果指定标签不在可以使用右键菜单的列表中,那么就使用ev.preventdefault()阻止事件冒泡,这很重要,否则的话如果有元素嵌套,虽然子元素禁用了右键菜单,但是右键子元素的时候,还是会弹出右键菜单,因为事件传递到父元素上去了,return false也可以禁用右键菜单了

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网