《JS事件处理》
Event对象详细信息:http://www.w3school.com.cn/jsref/dom_obj_event.asp
JS原生支持3中绑定事件方式:
1.以标签属性形式
<div onclick="clicked(event)"></div>
本质上这种方式是直接执行引号当中的JS语句。
2.以DOMObject对象属性赋值方式
var div=document.getElementById("div");
div.onclick=function(e){...};
3.以事件侦听器方式:
div.addEventListener("click",function(e){...},bool);
默认false,代表冒泡。
一个完整的浏览器事件流:
window->document->html->body->bigDiv->div->[p]->div->bigDiv->...->window
注意,从window到p,再从p到window,中间目标元素p会触发两次。比如,给p加上true和false两个事件侦听器,那么点击p标签,console先后输出true的event和false的event。
标准的Event属性:
1.bubbles         返回布尔值,如果事件是起泡类型为true,否则为fasle(其值就是addEventListener时的第三个参数值)
2.cancelable      返回布尔值,如果preventDefault方法可以取消与事件关联的默认动作,则为true,否则为fasle
3.currentTarget   返回事件传播到的这个元素
4.eventPhase      返回事件传播的当前阶段,它的值是下面的三个常量之一(Event.CAPTURING_PHASE == 1,Event.AT_TARGET == 2,Event.BUBBLING_PHASE == 3),分别表示捕获、目标和起泡阶段
5.target          返回发生事件的元素
6.timeStamp       返回一个从网页被打开到触发该事件的毫秒数
7.type            返回这个事件的事件类型
误区解释:
target & currentTarget傻傻分不清?看下面例子就懂了:
<div id="one">
   <div id="three"></div>
</div>
one.addEventListener("click",function(e){
   console.log(e.target);         //three
   console.log(e.currentTarget);  //one
},false);
注释:点击three,在冒泡阶段,从three开始向window传播时经过了one,即传播到了one这个元素,one绑定了click事件,这时触发对应的事件处理函数,然后先后输出three和one。另外,这事件处理函数中,关键词this等价于currentTarget。
标准的Event方法:
preventDefault()           通知浏览器不要执行与事件关联的默认动作(如果该元素的e.cancelable==false,说明不存在默认动作或无法阻止该元素的默认动作,只要cancelable为假,该方法不起作用)
stopPropagation()          不再派发事件(可以在捕获、目标、冒泡各阶段使用来停止事件传播)
stopImmediatePropagation() 不再派发事件(可以在捕获、目标、冒泡各阶段使用来停止事件传播)
误区解释:
stopPropagation() & stopImmediatePropagation()傻傻分不清?看下面例子就懂了:
<div id = "div1">
    <button id = "button1"></button>
</div>
var div = document.getElementById("div1");
var btn = document.getElementById("button1");
div.addEventListener("click" ,function(){alert("第一次执行");} ,true);//1
div.addEventListener("click" ,function(){alert("第二次执行");} ,true);//2
btn.addEventListener("click" ,function(){alert("button 执行");});  
这两者区别仅仅发生在对一个元素的一个阶段(冒泡或捕获)绑定了多个事件处理函数时(多个事件处理函数顺序按照定义时的顺序),如上面,如果在//1这行的alert后加上stopImmediatePropagation()那么只会弹出一个对话框“第一次自行”,但是如果换成stopPropagation()会弹出“第一次执行”和“第二次执行”。
简单的说下return false:(极其不赞成使用,现在return false只会阻止默认行为,不会停止事件传播)
1.使用事件侦听器注册的事件处理函数里面使用该语句无任何效果,不能阻止默认行为
2.使用DOMObj=onclick=function(e){...}注册的事件处理函数,该语句能阻止默认行为
3.在标签里面使用onclick="fun(event)",然后fun函数里面写了该语句,无法阻止默认行为
4.在标签里面使用onclick="return fun(event)",然后fun函数里面写了该语句,能阻止默认行为
5.在标签里面使用onclick="return false",能阻止默认行为
也就是说,使用return false阻止默认行为只有两种情况:
1,在标签属性里面写return false,这就是上述4和5的情况
2,在DOMObj的事件处理函数里面写return false,这就是上述2的情况

关于JavaScript的事件处理一些知识的更多相关文章

  1. 20个优秀的 JavaScript 键盘事件处理库

    键盘事件是 Web 开发中最常用的事件之一,通过对键盘事件的捕获和处理可以提高网站的易用性和交互体验.下面,我们向大家介绍收集的20款优秀的 JavaScript 键盘事件处理库,帮助开发人员轻松处理 ...

  2. 《JavaScript》 程序基本知识 数据类型。 {0912上} {0912下}

    JS脚本语言: 这是JaxaScript的全称名 JS是网页里面使用的脚本语言 JS是一个非常强大的语言 JS的基础语法 注释语法:  单行注释 //     多行注释 /**/ 输出语法:   双标 ...

  3. 20个优秀的JavaScript 键盘事件处理库

    键盘事件是 Web 开发中最常用的事件之一,通过对键盘事件的捕获和处理可以提高网站的易用性和交互体验.下面,我们向大家介绍收集的20款优秀的 JavaScript 键盘事件处理库,帮助开发人员轻松处理 ...

  4. javascript之正则表达式基础知识小结

    javascript之正则表达式基础知识小结,对于学习正则表达式的朋友是个不错的基础入门资料.   元字符 ^ $ . * + ? = ! : | \ / ( ) [ ] { } 在使用这些符号时需要 ...

  5. 摘:JavaScript性能优化小知识总结

    原文地址:http://www.codeceo.com/article/javascript-performance-tips.html JavaScript的性能问题不容小觑,这就需要我们开发人员在 ...

  6. JavaScript性能优化小知识总结

    原文出处: YouYaInsist   欢迎分享原创到伯乐头条 前言 一直在学习javascript,也有看过<犀利开发Jquery内核详解与实践>,对这本书的评价只有两个字犀利,可能是对 ...

  7. JavaScript性能优化小知识总结(转)

    JavaScript的性能问题不容小觑,这就需要我们开发人员在编写JavaScript程序时多注意一些细节,本文非常详细的介绍了一下JavaScript性能优化方面的知识点,绝对是干货. 前言 一直在 ...

  8. JavaScript学习笔记(一):介绍JavaScript的一些简单知识

    JavaScript是世界上最流行的编程语言.这门语言可用于HTML和web,更可广泛用于服务器.PC.笔记本电脑和智能手机等设备.---------------------------------- ...

  9. JavaScript之事件处理详解

    一.事件传播机制 客户端JavaScript程序(就是浏览器啦)采用了异步事件驱动编程模型.当文档.浏览器.元素或与之相关的对象发生某些有趣的事情时,Web浏览器就会产生事件(event).如果Jav ...

随机推荐

  1. Debug模式下程序卡

    Debug通常称为调试版本,它包含调试信息,并且不作任何优化,便于程序员调试程序.Release称为发布版本,它往往是进行了各种优化,使得程序在代码大小和运行速度上都是最优的,以便用户很好地使用. D ...

  2. Android开发——BroadcastReceiver广播的使用

    想要了解广播定义及相关原理的可以看下这一篇BroadcastReceiver史上最全面解析 简单地对广播进行分类吧,广播有两个角色,一个是广播发送者,另外一个是广播接收者 广播按照类型分为两种,一种是 ...

  3. KEIL MDK 查看代码量、RAM使用情况--RO-data、RW-data、ZI-data

    KEIL RVMDK编译后的信息 Code是代码占用的空间, RO-data是 Read Only 只读常量的大小,如const型, RW-data是(Read Write) 初始化了的可读写变量的大 ...

  4. Yourphp是一款完全开源免费的.核心采用了Thinkphp框架

    Yourphp企业网站管理系统,是一款完全开源免费的PHP+MYSQL系统.核心采用了Thinkphp框架,同时也作为开源软件发布.集众多开源项目于一身的特点,使本系统从安全,效率,易用及可扩展性上更 ...

  5. Java多线程异常处理

    在java多线程程序中,所有线程都不允许抛出未捕获的checked exception,也就是说各个线程需要自己把自己的checked exception处理掉.这一点是通过java.lang.Run ...

  6. jQuery——动态给表格添加序号

    摘录自:http://www.cnblogs.com/picaso/archive/2012/10/08/2715564.html 很多时候遇到需要对表格动态操作,而且一般都会有表格的序号,但是有时候 ...

  7. CCF系列之相反数(201403-1)

    试题名称: 相反数 试题编号: 201403-1时间限制: 1.0s 内存限制: 256.0MB 问题描述 有 N 个非零且各不相同的整数.请你编一个程序求出它们中有多少对相反数(a 和 -a 为一对 ...

  8. 1.MAVEN项目的创建与问题的解决

    一.创建一个maven-webapp.(环境:mac和15版本的IDEA) 二.next--->填写groupId(公司单位的名字,你组织的名字)和ArtifactID(有关tomcat,以后用 ...

  9. 重温MFC

    1. Button控件 2. 旋转和高级编辑控件 3. 标签控件和属性页 4. 列表控件 5. 树控件 6. 进度条控件和滑动条控件 7. 滚动条 8.工具栏和状态栏

  10. Linux指令--mkdir

    本篇博客参照http://www.cnblogs.com/peida/archive/2012/10/25/2738271.html. linux mkdir 命令用来创建指定的名称的目录,要求创建目 ...