JS的事件对象和事件冒泡
2016-02-24 17:22
549 查看
1、事件对象
js的事件对象中保存了当前被触发事件的一些相关的属性信息,如事件源、事件发生时的鼠标位置、事件按键等。
事件对象的获取方法:
IE中可以window.event直接获取,而Firefox中则不可以,可通过如下方法获取:
1)var event = window.event || arguments.callee.caller.arguments[0];
2)通过参数传。function(e) { var event = window.event || e; }
2、事件源
事件源即事件发生所在的元素(是最里层元素),在IE中用event.srcElement获取,在Firefox中用event.target获取。兼容性代码如下:
var event = window.event || arguments.callee.caller.arguments[0];
var targetObj = event.srcElement || event.target;
3、事件冒泡
在默认情况下,发生在一个子元素上的单击事件(或者其他事件),如果在其父级元素绑定了一个同样的事件,此时点击子元素,click事件会首先被子元素捕获,执行绑定的事件程序,之后会被父级元素捕获,再次激发一段脚本的执行,这就是所谓的“事件冒泡”。
但有的时候,在一个子元素上处理完单击事件后,不想触发其父元素的相同事件,则需要阻止冒泡的发生,阻止冒泡的方法如下:
在IE里使用 window.event.cancelBubble = true;
在Firefox里使用 event.stopPropagation();
兼容性代码如下所示:
var event = window.event || arguments.callee.caller.arguments[0];
if (event.stopPropagation) { event.stopPropagation(); } else { event.cancelBubble = true; }
4、jQuery对DOM的事件触发具有冒泡特性,jQuery.Event对象是符合W3C标准的一个事件对象,同时jQuery.Event免去了检查兼容IE的步骤。jQuery.Event提供了一个非常简单的方法来阻止事件冒泡:event.stopPropagation();示例代码如下:
$("div").click(function(event) { event.stopPropagation(); });
但是上面方法对使用live 绑定的事件没有作用,需要一个更简单的方法阻止事件冒泡:return false;示例代码如下:
$("div").live(function() {
//do something..
return false;
});
注意:event.stopPropagation()和return false两种阻止事件冒泡的方式有一些区别:return false 不仅阻止了事件往上冒泡,而且阻止了事件本身;event.stopPropagation() 则只阻止事件往上冒泡,不阻止事件本身,比如如下代码将导致单击文件浏览按钮,无法弹出文件浏览对话框。
<div id="panel">
<input type="file" id="fileBtn"/>
</div>
<script type="text/javascript">
$("#panel").click(function() {
return false; //return false在阻止冒泡的同时也会取消当前事件本身,这将阻止文件浏览对话框弹出
});
</script>
5、阻止事件的默认行为(比如使文本输入框的键盘输入不起作用)
上面说了阻止事件冒泡,但是事件的默认行为还是会发生,只不过事件不会再往上一级节点传递。阻止事件的默认行为的方式如下:
1)原生JS的方式:
[javascript] view
plain copy
//如果提供了事件对象,则这是一个非IE浏览器
if (event && event.preventDefault) {
//阻止默认浏览器动作(W3C)
event.preventDefault();
} else {
//IE中阻止函数器默认动作的方式
window.event.returnValue = false;
}
return false;
2)jQuery的方式
在上面的第4点中已经说过了,直接返回false就行
js的事件对象中保存了当前被触发事件的一些相关的属性信息,如事件源、事件发生时的鼠标位置、事件按键等。
事件对象的获取方法:
IE中可以window.event直接获取,而Firefox中则不可以,可通过如下方法获取:
1)var event = window.event || arguments.callee.caller.arguments[0];
2)通过参数传。function(e) { var event = window.event || e; }
2、事件源
事件源即事件发生所在的元素(是最里层元素),在IE中用event.srcElement获取,在Firefox中用event.target获取。兼容性代码如下:
var event = window.event || arguments.callee.caller.arguments[0];
var targetObj = event.srcElement || event.target;
3、事件冒泡
在默认情况下,发生在一个子元素上的单击事件(或者其他事件),如果在其父级元素绑定了一个同样的事件,此时点击子元素,click事件会首先被子元素捕获,执行绑定的事件程序,之后会被父级元素捕获,再次激发一段脚本的执行,这就是所谓的“事件冒泡”。
但有的时候,在一个子元素上处理完单击事件后,不想触发其父元素的相同事件,则需要阻止冒泡的发生,阻止冒泡的方法如下:
在IE里使用 window.event.cancelBubble = true;
在Firefox里使用 event.stopPropagation();
兼容性代码如下所示:
var event = window.event || arguments.callee.caller.arguments[0];
if (event.stopPropagation) { event.stopPropagation(); } else { event.cancelBubble = true; }
4、jQuery对DOM的事件触发具有冒泡特性,jQuery.Event对象是符合W3C标准的一个事件对象,同时jQuery.Event免去了检查兼容IE的步骤。jQuery.Event提供了一个非常简单的方法来阻止事件冒泡:event.stopPropagation();示例代码如下:
$("div").click(function(event) { event.stopPropagation(); });
但是上面方法对使用live 绑定的事件没有作用,需要一个更简单的方法阻止事件冒泡:return false;示例代码如下:
$("div").live(function() {
//do something..
return false;
});
注意:event.stopPropagation()和return false两种阻止事件冒泡的方式有一些区别:return false 不仅阻止了事件往上冒泡,而且阻止了事件本身;event.stopPropagation() 则只阻止事件往上冒泡,不阻止事件本身,比如如下代码将导致单击文件浏览按钮,无法弹出文件浏览对话框。
<div id="panel">
<input type="file" id="fileBtn"/>
</div>
<script type="text/javascript">
$("#panel").click(function() {
return false; //return false在阻止冒泡的同时也会取消当前事件本身,这将阻止文件浏览对话框弹出
});
</script>
5、阻止事件的默认行为(比如使文本输入框的键盘输入不起作用)
上面说了阻止事件冒泡,但是事件的默认行为还是会发生,只不过事件不会再往上一级节点传递。阻止事件的默认行为的方式如下:
1)原生JS的方式:
[javascript] view
plain copy
//如果提供了事件对象,则这是一个非IE浏览器
if (event && event.preventDefault) {
//阻止默认浏览器动作(W3C)
event.preventDefault();
} else {
//IE中阻止函数器默认动作的方式
window.event.returnValue = false;
}
return false;
2)jQuery的方式
在上面的第4点中已经说过了,直接返回false就行
相关文章推荐
- js冒泡/捕获事件及阻止冒泡方法详细总结
- JavaScript实现多种排序算法
- js鼠标右键的方法
- 视频插件VideoJS5介绍
- 在jsp中解决div的scroll浮动不匹配的情况
- webkit js扩展方式之Binding添加新DOM对象
- JavaScript中的时间处理小结
- 在Javascript 中的Base64加密,支持中文加密及emoji表情的unicode编码的base64加密
- json封装 与 解析
- javascript:void(0)和onclick=fn(this)
- 自制ichartjs饼图
- js正则标志/g /i /m的用法,以及实例
- 重写Extjs的confirm框
- uglifyjs压缩JS
- js基础知识五(String()函数,toString()函数)
- js框架说明
- js之date()
- js 全选全不选
- js获取地址栏参数
- 自动补全插件autocomplete.js的使用示例