事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包括了关于该事件的基本属性,事件类型type(click、dbclick等值)、目标元素target(我的理解是事件源对象,即触发该事件的dom元素)等,以及一些与该事件相关的方法。取消事件默认行为preventDefault()、组织事件继续冒泡或捕获stopPropagation()等等,这里我仅仅列举了,项目中我用到的属性和方法。

既然事件被触发。就随之产生了一个event对象。笔者在IE中測试了。不须要通过赋值就可以使用,也许低版本号的须要吧,火狐浏览器是须要对其进行赋值的,在这里我认为须要养成一个习惯。多谢一行代码呗。每次在事件处理程序中使用event对象,都通过赋值的方式去使用:

var event = event||window.event;

事实上,默认參数数组中第一元素就是event对象,也就是说,能够用数组元素赋值

var event = arguments[0];

type属性。应该是最easy理解的,事件类型。单击click,双击dbclick等等

target属性,触发事件的dom元素对象。我看到网上说target是火狐浏览器。srcElement是IE中的,可是我測试的结果是。在IE11中两个都能够使用了,一样的效果。可是火狐中仅仅能使用target属性,浏览器之间的实现方式能不能有个通用的标准呢,兼容性非常纠结呢,所以和event对象的获取一样,建议是通过赋值的方式去获取触发事件的dom对象:

var target = event.target||event.srcElement;

preventDefault()方法是用来取消默认事件行为的,比方超链接,点击超链接,会依据href属性,跳到还有一个页面。之前在项目中。就遇到非常多须要取消超链接的默认点击行为,在点击事件处理程序中。取消默认的事件行为,能够例如以下操作:

if(event.preventDefault){//推断该函数是否存在
event.preventDefault;
}else{
returnValue = false;
}

这样也实现了取消超链接的默认行为,事实上在项目中,还看到别的同事使用的别的方式,也取消是默认的点击行为

<a href="javaScript:void(0);">也行</a>

stopPropagation()方法直接就取消事件的继续冒泡或者捕获了,这个非常有用的,假设父元素和子元素都绑定了某个相同类型的事件,比方都绑定了click事件。如今用户触发了一个事件,事件在捕获阶段被触发,针对父元素,则会继续向下捕获。进而触发子元素的事件。针对子元素。在冒泡阶段被触发,也相同由于冒泡行为,会触发父元素的事件。因此往往须要取消这样的无意的触发。

if(event.stopPropagation){//推断是否存在
event.stopPropagation();
}else{
event.cancleBubble = true;
}

2014年9月30日22:04:18

兴许项目中。假设还是用到了别的相关操作,我在继续补充

javaScript中的事件对象event的更多相关文章

  1. javaScript中的事件对象event是怎样

    事件对象event,每当一个事件被触发的时候,就会随之产恒一个事件对象event,该对象中主要包含了关于该事件的基本属性,事件类型type(click.dbclick等值).目标元素target(我的 ...

  2. JavaScript中的事件对象

    JavaScript中的事件对象 JavaScript中的事件对象是非常重要的,恐怕是我们在项目中使用的最多的了.在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含这所有与事件有 ...

  3. JavaScript 中的事件对象(读书笔记思维导图)

    在触发 DOM 上的某个事件时,会产生一个事件对象 event,这个对象中包含着所有与事件有关的信息.包括导致事件的元素.事件的类型以及其他与特定事件相关的信息.例如,鼠标操作导致的事件对象中,会包含 ...

  4. Javascript中的事件对象和事件类型

    接上次看JS的事件冒泡和捕获,所以顺带就把事件相关的知识都看完好了 而且想到一个好的学习方法,第一天自己看,第二天把前一天学习的东西写下来,一方面可以当复习,一方面当重新整理并且分享 事件对象 事件处 ...

  5. javaScript动画3 事件对象event onmousemove

    事件对象的获取(event的获取) var event = event || window.event;(主要用这种) screenX.pageX和clientX的区别 PageY/pageX: 鼠标 ...

  6. 彻底理解javascript 中的事件对象的pageY, clientY, screenY的区别和联系。

    说到底, pageY, clientY, screenY的计算,就是要找到参考点, 它们的值就是: 鼠标点击的点----------- 和参考点指点----------的直角坐标系的距离 stacko ...

  7. 谈谈事件对象-event

    JavaScript 中的事件对象(event) 当我们每次触发一种事件(如点击事件),我们会在回调函数中传入事件对象event.今天就来来谈谈. 1.当我们想判断当前事件是我们想要的事件类型时,可以 ...

  8. javascript中的事件Event

    一.事件流 1.事件流:描述的是从页面中接受事件的顺序 IE的事件流是事件冒泡流,Netscape的事件流是事件捕获流. 2.事件冒泡 IE的事件流叫做事件冒泡(event bubbing),即事件开 ...

  9. JavaScript:事件对象Event和冒泡

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. 绑定事件的两种方式 我们在上一篇文章中已经讲过事件的概念.这里讲一下注册 ...

随机推荐

  1. 均匀分布(uniform distribution)期望的最大似然估计(maximum likelihood estimation)

    maximum estimator method more known as MLE of a uniform distribution [0,θ] 区间上的均匀分布为例,独立同分布地采样样本 x1, ...

  2. 修改mysql连接的密码

    mysql8.0修改密码: ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '你的password'; msyql开启实现 ...

  3. redis的windows版本下载地址及windows的客户端工具

    源码:https://github.com/MSOpenTech/redis 安装包:https://github.com/MSOpenTech/redis/releases 客户端工具:https: ...

  4. 软件测试作业-selenium

    一.作业要求 1.安装SeleniumIDE插件. 2.学会使用SeleniumIDE录制脚本和导出脚本. 3.访问网址使用学号登录系统,进入系统后可以看到该同学的git地址. 4.编写Seleniu ...

  5. Android 网络状态变化的监听

    1.在流量网页,时实现断网,提醒等功能. 需要权限 <uses-permission android:name="android.permission.INTERNET"/& ...

  6. c# ExecuteScalar()

    ExecuteScalar这个方法是从数据库中检索单个值返回值是object类型,必须用与它在数据库里存放的类型相同类型或者可以转换成的类型,比如数据是nchar类型值为 "123" ...

  7. 跟着8张思维导图学习javascript (转)

    学习的道路就是要不断的总结归纳,好记性不如烂笔头,so,下面将po出8张javascript相关的思维导图. 思维导图小tips:思维导图又叫心智图,是表达发射性思维的有效的图形思维工具 ,它简单却又 ...

  8. C++ should define all local variable outside the loop?

    see the following two examples, the conclusion is that we should define variable in the loop if it c ...

  9. 路飞学城Python-Day19(practise)

    # 特性1.继承:2.多态:3.封装 # 1.继承的用处:通过继承就可以解决类与类之间的代码冗余关系 # 2.多态的用处:1.增加了程序的灵活性,以不变应万变,使用者都是同一种形式去调用(func(a ...

  10. Python笔记(28)-----继承

    来自https://blog.csdn.net/sunwukong_hadoop/article/details/80175292 1.Python的继承以及调用父类成员 python子类调用父类成员 ...