javascript 事件代理及应用
事件代理又叫事件委托在前端发开中实际是非常有用的,说事件代理之前我们先说说事件绑定
<p onclick="test()" ></p>
function test(){
do something.....
alert(this);
}
js 代码和 html 代码耦合在了一起,不便于维护和开发,尽量不要使用这种方法绑定事件,还有一个不好的地方这样绑定事件this指向的是window而不是元素本身。
或者可以这样绑定
<p class="text" >22</p>
var Text = document.querySelector('.text');
Text.onclick = function(){
alert(this.innerText) //22
}
还有一种事件绑定(监听)的方法由于ie 和w3c提供的api不同存在兼容性问题一般要自己封装一下做兼容性的处理。
<p id="test">22</p>
var addEvent = function(elem,type,handler){
if(window.addEventListener){
addEvent = function(elem,type,handler){
elem.addEventListener(type,handler,false);
}
}else if(window.attachEvent){
addEvent = function(elem,type,handler){
elem.attachEvent('on'+type,handler);
}
}
addEvent(elem,type,handler);
}
var inp = document.querySelector("#test");
addEvent(inp,'click',test);
function test(){
alert(this.innerText); // 弹出22
}
好到现在为止常见的事件绑定方式说的都差不多了,事件代理的前提是要有事件绑定通过对父级或者父父级元素进行绑定看下面的例子。
<ul class="list">
<li>1233</li>
<li>222</li>
<li>333</li>
<li>444</li>
</ul>
<script>
var oUl = document.querySelector(".list");
oUl.onclick=function(e){
e = e || window.event;
var elem = e.target || e.srcElemnt;
if(elem.tagName.toLowerCase() === 'li'){
alert(elem.innerText);
}
}
</script>
上面的几个例子都是alert出元素的innerText但是采用事件代理方式性能会跟好,因为他不需要给每一个li绑定一个事件只需要给父级绑定一个事件即可。我们看看jq实现事件代理的方式
<ul class="list">
<li>1233</li>
<li>222</li>
<li>333</li>
<li>444</li>
</ul>
<script>
$('.list').on('click','li',delegate)
function delegate(){
alert($(this).text());
}
//或者这样但是推荐使用上面种方式 $('.list').delegate('li','click',delegate);
</script>
使用事件代理的时候有一点需要注意的就是事件冒泡如果你的目标元素(上面的例子li就是目标元素)和目标元素父级或者父父级的tagNanme(标签名)相同的话事件就会冒泡的相同标签名的父级上这是就需要阻止事件冒泡。来看一个例子
<style>
.box1{
position:relative;
width:300px;
height: 300px;
background:red;
}
.box2{
position:absolute;
top:50px;
left:50px;
width:200px;
height:200px;
background:yellow;
}
.box3{
top:50px;
left:50px;
position:absolute;
width:100px;
height:100px;
background:blue;
}
</style>
<div class="box1" >
box1
<div class="box2">
box2
<div class="box3">
box3
</div>
</div>
</div>
<script>
$('.box1').on('click','div',delegate)
function delegate(){
alert($(this).text());
}
//$('.list').delegate('li','click',delegate);
</script>

在上面的例子中给box1绑定了一个事件弹出box1下面div的innerText当我们点击box3的时候对话框弹出了两次一次是box3的innerText一次是box2的innerText说明事件冒泡到了box3的父级box2哪里也被触发了一次aler innerText 这个时候我们就要用的阻止事件冒泡了。
<style>
.box1{
position:relative;
width:300px;
height: 300px;
background:red;
}
.box2{
position:absolute;
top:50px;
left:50px;
width:200px;
height:200px;
background:yellow;
}
.box3{
top:50px;
left:50px;
position:absolute;
width:100px;
height:100px;
background:blue;
}
</style>
<div class="box1" >
box1
<div class="box2">
box2
<div class="box3">
box3
</div>
</div>
</div>
<script>
$('.box1').on('click','div',delegate)
function delegate(e){
e.stopPropagation();
alert($(this).text());
}
//$('.list').delegate('li','click',delegate);
</script>
在原有的基础上多加了一句 e.stopPropagation(); 这样就可以得到我们想要的效果了。
事件代理一般用在什么样的场景呢?
1 当有多个相同标签名的元素需要绑定事件的时候如ul 下面的li需要给每个li绑定事件 我们就可以给ul去绑定事件去做处理。
2 从后端获取数据生成的节点元素需要绑定事件的时候。
javascript 事件代理及应用的更多相关文章
- JavaScript事件代理和委托(Delegation)
JavaScript事件代理 首先介绍一下JavaScript的事件代理.事件代理在JS世界中一个非常有用也很有趣的功能.当我们需要对很多元素添加事件的时候,可以通过将事件添加到它们的父节点而将事件委 ...
- JavaScript事件代理和委托
在javasript中,代理.委托经常出现. 那么它究竟在什么样的情况下使用?它的原理又是什么? 这里介绍一下javascript delegate的用法和原理,以及Dojo,jQuery等框架中de ...
- JavaScript 事件代理
转自:http://www.cnblogs.com/silence516/archive/2009/09/03/delegateEvent.html 如果你想给网页添加点JavaScript的交互性, ...
- 【转载】浅谈事件冒泡与事件捕获 - javascript 事件代理
原文:https://segmentfault.com/a/1190000000749838 事件冒泡与事件捕获 事件冒泡和事件捕获分别由微软和网景公司提出,这两个概念都是为了解决页面中事件流(事件发 ...
- JavaScript事件代理入门
事件代理(Event Delegation),又称之为事件委托.是 JavaScript 中常用绑定事件的常用技巧. 顾名思义,“事件代理”即是把原本需要绑定的事件委托给父元素,让父元素担当事件监听的 ...
- JavaScript事件代理和事件委托
一.概述: 那什么叫事件委托呢?它还有一个名字叫事件代理,JavaScript高级程序设计上讲:事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件.那这是什么意思呢?网上的 ...
- javascript事件代理(委托)
之前有接触过事件代理,但是印象并不深刻.这次记下来加强印象. 用个大家比较常见的代码举例子: html dom结构: <ul id="ul1"> <li>0 ...
- javascript事件代理(Event Delegation)
看了几篇文章,放上来供参考 司徒正美的文章,Event Delegation Made Easy --------------------------------------------------- ...
- JavaScript 事件代理绑定
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- tabbar加小红点
原文 http://blog.csdn.net/u013531246/article/details/44460115 #import <UIKit/UIKit.h> @interfa ...
- php中mail()改用msmtp发送邮件
php中的mail()函数默认调用的是sendmail,这次我将其换成了轻量级的msmtp.在次过程中涉及到:修改配置文件php.ini,创建配置文件msmtprc或(.msmtprc)并修改其权限. ...
- 课堂里学不到的C与C++那些事(一)
首先,声明一下这是一个系列的文章.至于整个系列有多少篇,笔者也不知道,不知道有多少篇,也不知道多久会更新一篇.反正只有一个原则,写出来的文 章能见得人才会公布出来.另外,我不是叫你逃课,而是觉得听课只 ...
- (原)Ubuntu16中使用nvidia官方提供的驱动,而非自带的驱动
转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5638185.html 安装完ubuntu16后,显卡显示的是Gallium... 在“设置-软件和更新 ...
- git merge 分支
把master merge到apple_campus1.git stash2.git checkout master3.git pull4.git checkout apple_campus5.git ...
- Django auth 登陆后页面跳转至/account/profile,修改跳转至其他页面
这几天在学习django,django功能很强大,自带的auth,基本可以满足用户注册登陆登出,简单的用户注册登陆系统使用django auth足矣.当然也不是拿来就能用的,需要自己写登陆页面的模板, ...
- 【转】iOS代码规范
原文地址: http://www.cocoachina.com/ios/20150908/13335.html 简介: 本 文整理自Apple文档<Coding Guidelines for C ...
- Qt 框架的图形性能高(OpenGL上的系统效率高),网络性能低,开发效率高,Quick是可以走硬件加速——Qt中分为好几套图形系统,差不多代表了2D描画的发展史。最经典的软描画系统
-----图形性能部分-----Qt的widgets部分,运行时的图像渲染性能是一般的,因为大部分的界面内容都是Qt自绘,没有走硬件加速,也就是说很多图形内容都是CPU算出来的.但是widgets底层 ...
- 在一个exe文件中查找指定内容,找到则返回起始位置, 否则返回0
//在一个exe文件中查找指定内容,找到则返回起始位置, 否则返回0//如果某字符串, 直接传入字符串进来//如果要查找16进制,则用如下格式传参进来: #$1A#$2A#$3A function F ...
- DataTable类
DataTable是一个使用非常多的类,记得我在刚刚开始学习.Net的时候就已经了解并用过这个类,但如今再来看看,才发现这个类非常之复杂,复杂表现在哪些地方呢?主要是这个类与其他很多类都有关联,也就是 ...