JS和JQuery中的事件托付 学习笔记
事件托付事实上并非一个非常高级的技巧,比方在一个页面里面。当仅仅存在两个button的时候。可能你给button加入监听是这种:(本文不考虑浏览器兼容性。关于事件的兼容性可參考前面的学习笔记)
<div id="container">
<button id="btn1">button1</button>
<button id="btn2">button2</button>
</div>
var btn1 = document.getElementById("btn1");
var btn2 = document.getElementById("btn2");
btn1.addEventListener("click", clickHandler1);
btn2.addEventListener("click", clickHandler2);
当button越来越多的时候。甚至到了几十上百的时候。我相信非常少有人会选择一个一个的加入事件,首先。事实上事件处理函数每一个都是对象,都会占用内存,创建的越多。内存开销越大,性能越差;其次。大量“反复”性的代码拥挤在脚本里,非常难以维护,也非常难看。还有。加入大量监听意味着要频繁訪问DOM元素,延迟整个页面的訪问时间。
事件托付就是解决问题的一个方案。
我们知道。在DOM节点构成的DOM树中,子节点产生一个事件之后会逐级冒泡到父元素上:
事件托付就利用这一特性。仅仅需给全部的button的父元素比方container加入一个事件,这样无论是哪个button,仅仅要触发了绑定的事件都会冒泡到container上,我们仅仅需推断是不是你想监听的button就可以。
var container = document.getElementById("container");
container.addEventListener("click", function(e){
//获取事件触发对象
var target = e.target;
if(target.id == "btn1"){
alert("btn1");
}else if(target.id == "btn2"){
alert("btn2");
}
});
这种方法另一个明显的优点是你不必再问以后创建的元素加入监听。
比方在上面的推断里加入
else if(target.id == "btn3"){
alert("btn3");
}
加入这个事件处理程序的时候页面中还并没有btn3,但btn3非常可能是由用户动态创建的,但无论用户什么时候创建,你都能在这个条件里捕获它。
JQuery里面的事件托付
事实上在JQuery里。由于非常easy创建一个JQuery集合。所以处理事件相对简单。
一、click函数、bind函数等:
$("a").click(function(){
if($(this).hasClass("a1")){
//...
}else if(...){
//...
}
});
$("a").bind("click", function(){
if($(this).hasClass("a1")){
//...
}else if(...){
//...
}
});
事实上这种方法相同也是通过遍历全部a标签,给他们加入事件函数。但比原生js代码量要少非常多。
二、live()
live和上面讲的原生js相似。不指定父元素的时候,将事件绑定在了document上,比方:
$(".link").live("click", function(){
//...
});
当有事件冒泡到document上时。将检查事件是否为click事件,元素是否带有link的className。满足这两个条件则将触发事件处理函数。
除了默认绑定在document上。也能够绑定在指定父元素上:
$(".link", $("#container")).live("click", function(){
//...
});
三、delegate
事实上无论是live还是bind,他们的写法都非常奇怪,我们讨论的事件托付都是给父元素加入的事件监听,但一直到如今都好像是在子元素上调用的方法。只是还好JQuery里面另一个函数:delegate。
相同是绑定事件到.link筛选条件上,使用delegate方法例如以下:
$("#container").delegate(".link", "click", function(){
//...
});
能够看到,我们在须要绑定的父元素(id名为container的元素)上调用的delegate方法,并传递三个參数:监听元素筛选条件、监听事件名、事件处理函数。
通过链式调用更加舒服:
$("#container").delegate(".link", "click", function(){
//...
}).delegate(".btn", "click", function(){
//...
}).delegate(".whatever", "click", function(){
//...
});
注意
bind是不能为后面动态生成的元素绑定事件的(由于调用bind时遍历的是当时页面里的全部元素)。
live和delegate是能够为动态生成的元素触发事件处理函数的,由于绑定在父元素上的仅仅是一个筛选条件。
最后须要注意的是相同是绑定在document元素上的click事件:
$(".btn").live("click", function(){
//...
});
$("document").delegate(".btn", "click", function(){
//...
});
最好使用delegate方法,由于尽管live相同是绑定在document上。但$(“.btn”)这句代码还是会遍历全部的.btn元素并给其创建JQuery对象,相比于直接使用document,性能上会有所不如。
当然。就拿写法来说,我们也更应该喜欢delegate方法。
JS和JQuery中的事件托付 学习笔记的更多相关文章
- jQuery中的事件与动画 笔记整理
一. jQuery中的事件 jQuery事件是对javaScript事件的封装. 1.基础事件 在javaScript中,常用的基础事件有鼠标事件.键盘事件.window事件.表单事件.事件的绑定和处 ...
- JS和jQuery中的事件总结(一)
学而时习之,小白现在天天写页面,基础知识还是要恶补的. 进入正题,什么是事件(此处单独对jQuery.JS)?就是JS和Html之间的交互时呢,用户和浏览器操作页面时的动作(其实是为引发的效果的执行操 ...
- js和jQuery中的事件绑定与普通事件
普通事件,是指直接对元素进行事件注册,然后触发 而事件绑定是将事件注册到元素上 两者区别就是在于普通事件不可以重复添加多个事件,若添加也会覆盖,只会触发其中一个事件(最后注册的那个) 而事件绑定是可以 ...
- js和jquery中的事件委托
[转+自己的修改] 概念: 什么是事件委托:通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却 ...
- zepto.1.1.6.js源码中的each方法学习笔记
each方法接受要遍历的对象和对应的回调函数作为参数,它的作用是: 1.如果要遍历的对象是类似数组的形式(以该对象的length属性值的类型是否为number类型来判断),那么就把以要遍历的对象为执行 ...
- jQuery学习笔记(三)jQuery中的事件
目录 加载DOM 事件绑定 合成事件 事件冒泡 移除事件 一.加载DOM Javascript 与HTML之间的交互是通过用户操作浏览器页面引发的事件来处理的.jQuery提供了丰富的事件处理机制.从 ...
- 【jQuery基础学习】03 jQuery中的事件与动画
关于jQuery中的事件 js与HTML之间的交互是通过用户和浏览器操作页面时引发的事件来处理的. jQuery增加并扩展了基本的事件处理机制,jQuery不仅提供了更加优雅的事件处理方法,而且极大地 ...
- Javascript事件模型系列(三)jQuery中的事件监听方式及异同点
作为全球最知名的js框架之一,jQuery的火热程度堪称无与伦比,简单易学的API再加丰富的插件,几乎是每个前端程序员的必修课.从读<锋利的jQuery>开始,到现在使用jQuery有一年 ...
- Jquery中的事件和动画
在学习Jquery中的过程中我们绝大部分都用到了事件的操作,也可以说事件是Jquery中必不可少的一部分,我们常见的一些事件有单击事件,鼠标事件,键盘事件等等.在Jquery中的学习中为了能使让页面以 ...
随机推荐
- 阿里云ecs遭到频繁的ddos攻击始末
苦逼熬夜近俩月的时间搞出来个小东东,还指望它能给自己捞点~ 结果刚上线没多久就遭到竞争对手疯狂的ddos攻击. 可怜的阿里云默认只能抗住5G的攻击,超出的直接黑洞,也是很无奈,然而能免费抗5G这在国 ...
- 消息中间件ActiveMQ及Spring整合JMS的介绍
一 .消息中间件的基本介绍 1.1 消息中间件 1.1.1 什么是消息中间件 消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集成.通过提供消息传递和消息排 ...
- Java 核心内容相关面试题【3】
目录 面向对象编程(OOP) 常见的Java问题 Java线程 Java集合类 垃圾收集器 异常处理 Java小应用程序(Applet) Swing JDBC 远程方法调用(RMI) Servlet ...
- tomcat不编译webapps下的war包的解决办法
1.首先看看tomcat是否能正常启动,如果启动tomcat一闪而过那么就使用dos命令启动tomcat看看报什么错 如果是端口占用的错误.使用netstat -ano命令查看占用端口的程序 然后用任 ...
- SharpGL(46)用Billboard绘制头顶文字
CSharpGL(46)用Billboard绘制头顶文字 本文介绍CSharpGL用Billboard绘制头顶文字的方法.效果如下图所示. 下载 CSharpGL已在GitHub开源,欢迎对OpenG ...
- Windows Forms DataGridView中合并单元格
Windows Forms DataGridView 没有提供合并单元格的功能,要实现合并单元格的功能就要在CellPainting事件中使用Graphics.DrawLine和 Graphics.D ...
- WPF字符串中的换行符
<sys:String x:Key="NewUpdateWillShow" xml:space="preserve">第一行 第二行 </sy ...
- [最短路]P1462 通往奥格瑞玛的道路
题目背景 在艾泽拉斯大陆上有一位名叫歪嘴哦的神奇术士,他是部落的中坚力量 有一天他醒来后发现自己居然到了联盟的主城暴风城 在被众多联盟的士兵攻击后,他决定逃回自己的家乡奥格瑞玛 题目描述 在艾泽拉斯, ...
- 异常:This application has no explicit mapping for /error, so you are seeing this as a fallback.
出现这个异常说明了跳转页面的url无对应的值. 原因1: Application启动类的位置不对.要将Application类放在最外侧,即包含所有子包 原因:spring-boot会自动加载启动类所 ...
- [LeetCode] 74 Search a 2D Matrix(二分查找)
二分查找 1.二分查找的时间复杂度分析: 二分查找每次排除掉一半不合适的值,所以对于n个元素的情况来说: 一次二分剩下:n/2 两次:n/4 m次:n/(2^m) 最坏情况是排除到最后一个值之后得到结 ...