JavaScript FAQ(十五)——鼠标事件(二)

简介:  十二、鼠标事件 2. 左键 vs.右键(Left vs. Right Button)Q:我如何检查用户点击的是右键还是左键?A:click事件只在左键发生,因此onClick事件处理器不用进行左右键测试。

 十二、鼠标事件

 

2. 左键 vs.右键(Left vs. Right Button

Q:我如何检查用户点击的是右键还是左键?

Aclick事件只在左键发生,因此onClick事件处理器不用进行左右键测试。

另一方面,mousedownmouseup事件可能发生在鼠标的任何键上。要确定用户点击的是左键还是右键,可以使用下列事件属性:

  • Netscape Navigator中 event.which
  • Internet Explorer中 event.button

若这些属性的值是1,事件就发生在左键上。在下面的例子中,onMouseEvent事件处理器会根据你实际点击的鼠标显示Left button或者Right button。这个消息会出现在你的浏览器的状态栏上。点击或者右击页面的任何地方来观察它如何运行:

<script language="JavaScript"><!--
function mouseDown(e) {
 if (parseInt(navigator.appVersion)>3) {
  var clickType=1;
  if (navigator.appName=="Netscape") clickType=e.which;
  else clickType=event.button;
  if (clickType==1) self.status='Left button!';
  if (clickType!=1) self.status='Right button!';
 }
 return true;
}
if (parseInt(navigator.appVersion)>3) {
 document.onmousedown = mouseDown;
 if (navigator.appName=="Netscape") 
  document.captureEvents(Event.MOUSEDOWN);
}
// --></script>

 

3. 右键:不可用(Right Button: Disabling

Q:我可以在用哦过户点击右键时不弹出Windows上下文菜单吗?

A:在当今的多数浏览器中,你可以通过在页面的body标签中使用oncontextmenu时间处理器,阻止弹出上下文菜单。

<body oncontextmenu="return false;">

试着在页面上任何地方右击——上下文菜单都不会出现了。

在旧版的浏览器中(从Netscape Navigator 4.x和Internet Explorer 4.x开始你可以通过在右击时显示警告信息禁止右键菜单。把下面的代码插入页面的<HEAD>区域就可以完成上面的功能:

<script language="JavaScript"><!--
function mouseDown(e) {
 if (parseInt(navigator.appVersion)>3) {
  var clickType=1;
  if (navigator.appName=="Netscape") clickType=e.which;
  else clickType=event.button;
  if (clickType!=1) {
   alert ('Right mouse button is disabled.')
   return false;
  }
 }
 return true;
}
if (parseInt(navigator.appVersion)>3) {
 document.onmousedown = mouseDown;
 if (navigator.appName=="Netscape") 
  document.captureEvents(Event.MOUSEDOWN);
}
// --></script>

 

注意:在特别老的浏览器中(Netscape Navigator 3.x、Internet Explorer 3.x或者更早)上下文菜单仍旧会出现。另外,如果用户已经禁止了JavaScript,上下文菜单也会出现。

 

 

4. 图片上禁止右键菜单(Disabling the Right-Click Menu For an Image

Q:我可以只在一个图片上禁止右键菜单,而其他图片仍然显示吗?

A:可以。在当今多数的浏览其中,你可以在一个特定的图片上禁止右键菜单。为了实现这个功能,你可以在IMG标签内使用事件处理器oncontextmenu="return false;",图片定义:

<IMG border=0 src="..." oncontextmenu="return false;">

例如,这个图片的右键菜单已经被禁止了:

 

注意:在旧版的浏览器中(例如,Internet Explorer 4.x或者更早),这个技巧就不起作用。如果用户禁止了JavaScript,菜单也会出现。

目录
相关文章
|
JavaScript
鼠标事件(点击换色)分别使用js和jQuery代码实现
鼠标事件(点击换色)分别使用js和jQuery代码实现
119 1
|
存储 前端开发 JavaScript
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
本文介绍了JavaScript变量的声明和使用、标识符的命名规则、如何获取和操作HTML元素,以及JavaScript的鼠标事件处理,通过示例代码展示了这些基础知识点在实际开发中的应用。
145 2
前端基础(二)_JavaScript变量、JavaScript标识符、JavaScript获取元素、JavaScript的鼠标事件
|
JavaScript
js【图解】滚动条的位置(文档与屏幕间的距离),鼠标事件距离(位置),元素距离(位置)
js【图解】滚动条的位置(文档与屏幕间的距离),鼠标事件距离(位置),元素距离(位置)
304 7
|
前端开发 JavaScript
CSS+JS鼠标事件触发鼠标模形实现手状
CSS+JS鼠标事件触发鼠标模形实现手状
171 1
|
JavaScript 前端开发
js基础——事件(鼠标事件、键盘事件、表单事件......)
js基础——事件(鼠标事件、键盘事件、表单事件......)
142 0
|
JavaScript 前端开发
JS javascript 点击鼠标 鼠标事件 获取元素 获取元素Xpath
JS javascript 点击鼠标 鼠标事件 获取元素 获取元素Xpath
386 0
js鼠标事件对象
event对象代表事件的状态,跟事件相关的一系列信息的集合。
|
JavaScript 程序员
【JavaScript-事件】target和this的区别?如何阻止冒泡事件?常见的鼠标事件和键盘事件有哪些?
【JavaScript-事件】target和this的区别?如何阻止冒泡事件?常见的鼠标事件和键盘事件有哪些?
247 0
【JavaScript-事件】target和this的区别?如何阻止冒泡事件?常见的鼠标事件和键盘事件有哪些?
|
JavaScript 容器
js鼠标事件大全
js鼠标事件大全
194 0

热门文章

最新文章