js事件篇
javascript和html之间的交互式通过事件来实现的,事件就是文档或浏览器窗口中发生的一些特定的交互。
事件流:描述的是从页面中接收事件的顺序。
不同的是,IE和Netscape开发团队竟然提出了差不多是完全相反的事件流概念。IE的事件流失事件流冒泡,而Netscape的事件流是事件流捕获。
<div id="demo"><span id='demo1'>sdasd</span></div>
<script>
var oDiv = document.getElementById('demo');
var oDiv1 = document.getElementById('demo1');
oDiv.onclick = function(){
alert();
}
oDiv1.onclick = function(){
alert("abc");
}
</script>
以这段代码为例
事件冒泡:span->div->body->html->document->window
事件捕获: window->document->html->body->div->span
事件冒泡:
IE的事件流叫做事件冒泡,是指事件开始时由最具体的元素接收,然后逐级向上传播到较为不具体的节点。事件冒泡:span->div->body->html->document->window
事件捕获:
Netscape Communicator团队提出的另一种事件流叫做事件捕获,思想是不太具体的节点应该更早接收到事件,而最具体的节点应该最后接收到事件,事件捕获的用意在于在事件到达预定目标之前捕获它。事件捕获: window->document->html->body->div->span
事件处理程序:
<input onclick="alert(123)">
oDiv.onclick = function(){
alert();
}
oDiv.addEventListener('click',function(){
alert();
},false);
上面是三种事件处理方法,首先第一种方法不推荐,因为违反了HTML与JavaScript分离的准则。
第二种方法只能给一个事件绑定一个响应函数,重复绑定会覆盖之前的绑定。
第三种方法比较推荐,可以绑定多个不同的函数。
addEventListener这个方法有三个参数,第一个参数是你要绑定的事件,第二个参数是执行的函数,第三个参数有两个值(true flase)。
true表示该元素在事件的“捕获阶段”(由外往内传递时)响应事件,
false表示该元素在事件的“冒泡阶段”(由内往外传递时)响应事件;
IE事件处理程序:
IE实现了与DOM中类似的两个方法:attachEvent()和detachEvent()。
btn.attachEvent('click',function(){
alert();
});
由于IE8及更早版本只支持事件冒泡,所以通过attachEvent()添加的事件处理程序都会被添加到冒泡阶段。
下面我们来封装一个能力检测的js库的事件部分:
var oDiv = document.getElementById('demo');
var Event = {
addEvent:function(element,type,even){
if(element.addEventListener){
element.addEventListener(type,even,false);
}else if(element.attachEvent){
element.attachEvent('on'+type,even);
}else{
element["on"+type]=even;
}
},
removeEvent:function(element,type,even){
if(element.removeEventListener){
element.removeEventListener(type,even,false);
}else if(element.detachEvent){
element.detachEvent('on'+type,handler);
}else{
element["on"+type]=null;
}
}
};
Event.addEvent(oDiv,"click",function(){
alert();
});
下面我们来介绍一下如何取消事件(冒泡):
事件对象还提供了一个.stopPropagation()方法,该方法可以完全阻止事件冒泡。这个方法也是一种纯JavaScript特性,但在跨浏览器的环境中则无法安全地使用 。不过,只要我们通过jQuery来注册所有的事件处理程序,就可以放心地使用这个方法。w3c的方法是event.stopPropagation(),IE则是使用window.event.cancelBubble = true.
下面我们来封装一个取消事件冒泡的函数:
function stopEventBubble(event){
var e=event || window.event;
if (e && e.stopPropagation){
e.stopPropagation();
}
else{
e.cancelBubble=true;
}
}
是不是很简单呢?其实我们遇到的不都是事件的冒泡与捕获,我们在工作中还可能遇到一些其他的问题。
例如:
我们把单击事件注册到一个锚元素,当用户单击链接时,浏览器会加载一个新页面。这种行为和事件处理程序是不同的。类似地,当用户在编辑完表单后,会触发表单的submit事件,在此事件发生后,表单提交才会真正发生。如果我们不希望执行这种默认操作,那么在事件对象上调用.stopPropagation()方法也没用,因为默认操作不是在正常的事件传播流中发生的。在这种情况下,.preventDefault()方法则可以在触发默认操作之前终止事件 。
事件的传播和浏览器默认操作是相互独立的两套机制,在二者任何一方发生时,都可以终止另一方。
如果想要同时停止事件传播和默认操作,可以在事件处理程序中返回false。
return false;
最后:我们做的许许多多的东西只要涉及到交互就一定涉及到事件的绑定,所有学好js中事件的部分我认为还是非常有必要的,你说是吧?
js事件篇的更多相关文章
- [js]事件篇
一.事件流 1.冒泡事件:从特定的事件到不特定事件依次触发:(由DOM层次的底层依次向上冒泡) (1)示例: <html onclick="add('html<br>')& ...
- 2. web前端开发分享-css,js进阶篇
一,css进阶篇: 等css哪些事儿看了两三遍之后,需要对看过的知识综合应用,这时候需要大量的实践经验, 简单的想法:把qq首页全屏另存为jpg然后通过ps工具切图结合css转换成html,有无从下手 ...
- js事件监听器用法实例详解
这篇文章主要介绍了js事件监听器用法,以实例形式较为详细的分析了javascript事件监听器使用注意事项与相关技巧,需要的朋友可以参考下本文实例讲述了js事件监听器用法.分享给大家供大家参考.具体分 ...
- 移动终端学习2:触屏原生js事件及重力感应
如今智能移动设备已经渗透到人们生活的方方面面,用户数量也在不断迅速增长(市场研究机构 eMarketer 在今年初发表的趋势报告中预测,2014年至2018年,中国智能手机用户从总人口的 38.3%增 ...
- web前端开发分享-css,js进阶篇
一,css进阶篇: 等css哪些事儿看了两三遍之后,需要对看过的知识综合应用,这时候需要大量的实践 经验, 简单的想法:把qq首页全屏另存为jpg然后通过ps工具切图结合css转换成html,有无 从 ...
- css,js工具篇
4. web前端开发分享-css,js工具篇 web前端开发乃及其它的相关开发,推荐sublime text, webstorm(jetbrains公司系列产品)这两个的原因在于,有个技术叫emm ...
- 前端面试题目汇总摘录(JS 基础篇)
JS 基础 JavaScript 的 typeof 返回那些数据类型 object number function boolean undefined string typeof null; // o ...
- 这可能是最简明扼要的 js事件冒泡机制+阻止默认事件 讲解了
哎 js事件冒泡机制和阻止冒泡 阻止默认行为好像永远也整不清楚,记了忘 忘了记...醉了 这篇文章写完以后下次再忘记 就呼自己一巴掌,忘一次一巴掌 首先要明白两个概念——事件和事件流 事件指的是用户或 ...
- js事件委托 jQuery写法
http://www.cnblogs.com/liugang-vip/p/5616484.html 不是抄的,这篇文章写的细 这是js 事件委托写法 <!DOCTYPE html> < ...
随机推荐
- ansible入门五
一.Ansible条件测试 在ansible中还可以进行条件测试.如果需要根据变量.facts或此前任务的执行结果来做为某task执行与否的前提时要用到条件测试. 1. when语句 在task后添加 ...
- AngularJS如何修改URL中的参数
一. 获取url的相关方法(不修改URL): 1.获取当前完整的url路径 var absurl = $location.absUrl(); //http://172.16.0.88:8100/#/h ...
- FreeMarker初探--安装FreeMarker
这里安装FreeMarker相当简单,不需要真正的安装过程.仅仅是拷贝 lib/freemarker.jar 到你 Java 应用程序的路径中,让类加载器可以发现它.比如,如果你在 Web 使用了 F ...
- [C#]委托实例分析(附源码)
一直都听说C#中的委托与事件非常重要,都没有什么切身的体会,而这次通过做一个WinForm二次开发的项目才真正感觉到了委托与事件的犀利之处. 1.C#中的事件和委托的作用? 事件代表一个组件能够被关注 ...
- Winform 导航菜单的方法
http://blog.163.com/kunkun0921@126/blog/static/169204332201171610619611/ 第一种:使用OutlookBar第三方控件 第二种:使 ...
- PostgreSQL数据库资料(转)
PostgreSQL数据库资料 转自:http://blog.csdn.net/postgrechina/article/details/49132791 推荐书籍: 概念书籍: <Postgr ...
- Tornado 自定义session,与一致性哈希 ,基于redis 构建分布式 session框架
Tornado 自定义session,与一致性哈希 ,基于redis 构建分布式 session import tornado.ioloop import tornado.web from myhas ...
- 在ORACLE中移动数据库文件
转载: 在ORACLE中移动数据库文件 --ORACLE数据库由数据文件,控制文件和联机日志文件三种文件组成. --由于磁盘空间的变化,或者基于数据库磁盘I/O性能的调整等, --我們可能会考虑移动数 ...
- Weinre(pc调试手机页面)
Weinre是一款基于Web Inspector(Webkit)的远程调试工具,借助于网络,可以在PC上直接调试运行在移动设备上的远程页面,中文意思是远程Web检查器,有了Weinre,在P ...
- 【剑指offer】n个骰子的点数,C++实现
# 题目 # 思路 # 代码