javascript中window.event事件用法详解


Posted in Javascript onDecember 11, 2012

前两天写程序时因为要用到javascript中的window.event事件,于是就在网上搜了一下,终于找到一篇不错的文章,来与大家分享下:
描述
event代表事件的状态,例如触发event对象的元素、鼠标的位置及状态、按下的键等等。
event对象只在事件发生的过程中才有效。
event的某些属性只对特定的事件有意义。比如,fromElement 和 toElement 属性只对 onmouseover 和 onmouseout 事件有意义。
例子下面的例子检查鼠标是否在链接上单击,并且,如果shift键被按下,就取消链接的跳转。

<HTML> 
<HEAD><TITLE>Cancels Links</TITLE> 
<SCRIPT LANGUAGE=”JScript”> 
function cancelLink() { 
if (window.event.srcElement.tagName == “A” && window.event.shiftKey) 
window.event.returnValue = false; 
} 
</SCRIPT> 
<BODY onclick=”cancelLink()”>下面的例子在状态栏上显示鼠标的当前位置。 
<BODY onmousemove=”window.status = ‘X=' + window.event.x + ‘ Y=' + window.event.y”>属性: 
altKey, button, cancelBubble, clientX, clientY, ctrlKey, fromElement, keyCode, offsetX, offsetY, propertyName, returnValue, screenX, screenY, shiftKey, srcElement, srcFilter, toElement, type, x, y

1.altKey
描述:
检查alt键的状态。
语法:
event.altKey
可能的值:
当alt键按下时,值为 TRUE ,否则为 FALSE 。只读。

2.button
描述:
检查按下的鼠标键。
语法:
event.button
可能的值:
0 没按键
1 按左键
2 按右键
3 按左右键
4 按中间键
5 按左键和中间键
6 按右键和中间键
7 按所有的键
这个属性仅用于onmousedown, onmouseup, 和 onmousemove 事件。对其他事件,不管鼠标状态如何,都返回 0(比如onclick)。

3.cancelBubble
描述:
检测是否接受上层元素的事件的控制。
语法:
event.cancelBubble[ = cancelBubble]
可能的值:
这是一个可读写的布尔值:
TRUE 不被上层原素的事件控制。
FALSE 允许被上层元素的事件控制。这是默认值。
例子:
下面的代码片断演示了当在图片上点击(onclick)时,如果同时shift键也被按下,就取消上层元素(body)上的事件onclick所引发的showSrc()函数。

<SCRIPT LANGUAGE=”JScript”> 
function checkCancel() { 
if (window.event.shiftKey) 
window.event.cancelBubble = true; 
} 
function showSrc() { 
if (window.event.srcElement.tagName == “IMG”) 
alert(window.event.srcElement.src); 
} 
</SCRIPT> 
<BODY onclick=”showSrc()”> 
<IMG onclick=”checkCancel()” src=”/sample.gif”>4.clientX

描述:
返回鼠标在窗口客户区域中的X坐标。
语法:
event.clientX
注释:
这是个只读属性。这意味着,你只能通过它来得到鼠标的当前位置,却不能用它来更改鼠标的位置。

5.clientY
描述:
返回鼠标在窗口客户区域中的Y坐标。
语法:
event.clientY
注释:
这是个只读属性。这意味着,你只能通过它来得到鼠标的当前位置,却不能用它来更改鼠标的位置。

6.ctrlKey
描述:
检查ctrl键的状态。
语法:
event.ctrlKey
可能的值:
当ctrl键按下时,值为 TRUE ,否则为 FALSE 。只读。

7.fromElement
描述:
检测 onmouseover 和 onmouseout 事件发生时,鼠标所离开的元素。 参考:18.toElement
语法:
event.fromElement
注释:
这是个只读属性。

8.keyCode
描述:
检测键盘事件相对应的内码。
这个属性用于 onkeydown, onkeyup, 和 onkeypress 事件。
语法:
event.keyCode[ = keyCode]
可能的值:
这是个可读写的值,可以是任何一个Unicode键盘内码。如果没有引发键盘事件,则该值为 0 。

9.offsetX
描述:
检查相对于触发事件的对象,鼠标位置的水平坐标
语法:
event.offsetX

10.offsetY
描述:
检查相对于触发事件的对象,鼠标位置的垂直坐标
语法:
event.offsetY

11.propertyName
描述:
设置或返回元素的变化了的属性的名称。
语法:
event.propertyName [ = sProperty ]
可能的值:
sProperty 是一个字符串,指定或返回触发事件的元素在事件中变化了的属性的名称。
这个属性是可读写的。无默认值。
注释:
你可以通过使用 onpropertychange 事件,得到 propertyName 的值。
例子:
下面的例子通过使用 onpropertychange 事件,弹出一个对话框,显示 propertyName 的值。

<HEAD> 
<SCRIPT> 
function changeProp() 
{ 
btnProp.value = “This is the new VALUE”; 
} 
function changeCSSProp() 
{ 
btnStyleProp.style.backgroundColor = “aqua”; 
} 
</SCRIPT> 
</HEAD> 
<BODY> 
<P>The event object property propertyName is 
used here to return which property has been 
altered.</P> 
<INPUT TYPE=button ID=btnProp onclick=”changeProp()” 
VALUE=”Click to change the VALUE property of this button” 
onpropertychange='alert(event.propertyName+” property has changed value”)'> 
<INPUT TYPE=button ID=btnStyleProp 
onclick=”changeCSSProp()” 
VALUE=”Click to change the CSS backgroundColor property of this button” 
onpropertychange='alert(event.propertyName+” property has changed value”)'> 
</BODY>

12.returnValue
[/code]
描述:
设置或检查从事件中返回的值
语法:
event.returnValue[ = Boolean]
可能的值:
true 事件中的值被返回
false 源对象上事件的默认操作被取消
例子见本文的开头。

13.screenX
描述:
检测鼠标相对于用户屏幕的水平位置
语法:
event.screenX
注释:
这是个只读属性。这意味着,你只能通过它来得到鼠标的当前位置,却不能用它来更改鼠标的位置。

14.screenY
描述:
检测鼠标相对于用户屏幕的垂直位置
语法:
event.screenY
注释:
这是个只读属性。这意味着,你只能通过它来得到鼠标的当前位置,却不能用它来更改鼠标的位置。

15.shiftKey
描述:
检查shift键的状态。
语法:
event.shiftKey
可能的值:
当shift键按下时,值为 TRUE ,否则为 FALSE 。只读。

16.srcElement
描述:
返回触发事件的元素。只读。例子见本文开头。
语法:
event.srcElement

17.srcFilter
描述:
返回触发 onfilterchange 事件的滤镜。只读。
语法:
event.srcFilter

18.toElement
描述:
检测 onmouseover 和 onmouseout 事件发生时,鼠标所进入的元素。 参考:7.fromElement
语法:
event.toElement
注释:
这是个只读属性。
例子:下面的代码演示了当鼠标移到按钮上时,弹出一个对话框,显示“mouse arrived”

<SCRIPT> 
function testMouse(oObject) { 
if(oObject.contains(event.toElement)) { 
alert(“mouse arrived”); 
} 
} 
</SCRIPT> 
: 
<BUTTON ID=oButton onmouseover=”testMouse(this)”>Mouse Over This.</BUTTON>19.type

描述:
返回事件名。
语法:
event.type
注释:
返回没有“on”作为前缀的事件名,比如,onclick事件返回的type是click
只读。

20. x
描述:
返回鼠标相对于css属性中有position属性的上级元素的x轴坐标。如果没有css属性中有position属性的上级元素,默认以BODY元素作为参考对象。
语法:
event.x
注释:
如果事件触发后,鼠标移出窗口外,则返回的值为 -1
这是个只读属性。这意味着,你只能通过它来得到鼠标的当前位置,却不能用它来更改鼠标的位置。

21. y
描述:
返回鼠标相对于css属性中有position属性的上级元素的y轴坐标。如果没有css属性中有position属性的上级元素,默认以BODY元素作为参考对象。
语法:
event.y
注释:
如果事件触发后,鼠标移出窗口外,则返回的值为 -1
这是个只读属性。这意味着,你只能通过它来得到鼠标的当前位置,却不能用它来更改鼠标的位置。

Javascript 相关文章推荐
一个js过滤空格的小函数
Oct 10 Javascript
angular2使用简单介绍
Mar 01 Javascript
关于JS中的方法是否加括号的问题
Jul 27 Javascript
Javascript单例模式的介绍和实例
Oct 08 Javascript
jQuery事件与动画基础详解
Feb 23 Javascript
Angular多选、全选、批量选择操作实例代码
Mar 10 Javascript
Vue 实现点击空白处隐藏某节点的三种方式(指令、普通、遮罩)
Oct 23 Javascript
vue.js 子组件无法获取父组件store值的解决方式
Nov 08 Javascript
JavaScript实现简单计算器功能
Dec 19 Javascript
node.js使用zlib模块进行数据压缩和解压操作示例
Feb 12 Javascript
vue-cli3配置favicon.ico和title的流程
Oct 27 Javascript
Vue Element UI自定义描述列表组件
May 18 Vue.js
js 延迟加载 改变JS的位置加快网页加载速度
Dec 11 #Javascript
js控制CSS样式属性语法对照表
Dec 11 #Javascript
javascript向flash swf文件传递参数值注意细节
Dec 11 #Javascript
ajax的hide隐藏问题解决方法
Dec 11 #Javascript
ajax上传时参数提交不更新等相关问题
Dec 11 #Javascript
jQuery(非HTML5)可编辑表格实现代码
Dec 11 #Javascript
jQuery使用数组编写图片无缝向左滚动
Dec 11 #Javascript
You might like
2020年4月放送!《Princess Connect Re:Dive》制作组 & 角色声优公开!
2020/03/06 日漫
linux命令之调试工具strace的深入分析
2013/06/03 PHP
解析php中eclipse 用空格替换 tab键
2013/06/24 PHP
Thinkphp模板标签if和eq的区别和比较实例分析
2015/07/01 PHP
yii权限控制的方法(三种方法)
2015/12/28 PHP
JavaScript下利用fso判断文件是否存在的代码
2010/12/11 Javascript
Javascript Boolean、Nnumber、String 强制类型转换的区别详细介绍
2012/12/13 Javascript
深入理解JavaScript中的传值与传引用
2013/12/09 Javascript
JS日期加减,日期运算代码
2015/11/05 Javascript
js获取图片宽高的方法
2015/11/25 Javascript
Vue.js每天必学之数据双向绑定
2016/09/05 Javascript
vue.js表格分页示例
2016/10/18 Javascript
快速解决vue-cli不能初始化webpack模板的问题
2018/03/20 Javascript
Node.js中的不安全跳转如何防御详解
2018/10/21 Javascript
基于JS实现web端录音与播放功能
2019/04/17 Javascript
JS实现返回上一页并刷新页面的方法分析
2019/07/16 Javascript
如何正确理解vue中的key详解
2019/11/02 Javascript
vue实现购物车功能(商品分类)
2020/04/20 Javascript
浅析JavaScript 函数柯里化
2020/09/08 Javascript
[02:15]2014DOTA2国际邀请赛 专访LGD.lin小兔子是大腿
2014/07/14 DOTA
[43:58]DOTA2-DPC中国联赛定级赛 LBZS vs SAG BO3第一场 1月8日
2021/03/11 DOTA
[46:49]完美世界DOTA2联赛PWL S3 access vs Rebirth 第二场 12.19
2020/12/24 DOTA
python测试驱动开发实例
2014/10/08 Python
在Python中使用AOP实现Redis缓存示例
2017/07/11 Python
利用python实现简单的邮件发送客户端示例
2017/12/23 Python
python+selenium+chrome批量文件下载并自动创建文件夹实例
2020/04/27 Python
python如何对链表操作
2020/10/10 Python
Html5新增标签有哪些
2017/04/13 HTML / CSS
狗狗玩具、零食和咀嚼物的月度送货服务:Super Chewer
2018/08/22 全球购物
家长给幼儿园的表扬信
2014/01/09 职场文书
保安拾金不昧表扬信
2014/01/15 职场文书
上海世博会口号
2014/06/19 职场文书
国家助学金感谢信
2015/01/21 职场文书
小升初自荐信范文
2015/03/05 职场文书
公司职员入党自传书
2015/06/26 职场文书
行为习惯主题班会
2015/08/14 职场文书