JavaScript委托,js委托事件

如何理解JavaScript里的事件委托

首先要知道什么是事件冒泡。

创新互联公司长期为1000+客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为康马企业提供专业的网站设计、成都网站制作康马网站改版等技术服务。拥有10年丰富建站经验和众多成功案例,为您定制开发。

页面中一个li被点击,相当于其父元素ul,ul的父元素body,body的父元素都被点击。

既然如此,与其给100个li绑定100个事件,还不如给一个ul绑定一个事件,通过event.target来获取具体被点击的元素。

这就是事件委托。

[img]

在javascript中什么是事件委托 原理是什么

比方说a元素里面包含了b元素(或者说a元素是b元素的父元素),当b元素触发事件时,会同时把事件冒泡给a元素,也就是说a元素也会触发事件。利用这个原理,b元素就可以不对事件做任何处理,而是委托给a元素去处理,这样,当a元素中动态添加了多个与b元素同级的元素(也就是a新添加了几个儿子)或者是b元素的子元素(也就是a的孙子),这些新添加的元素都不用再绑定事件处理函数了,通通由a元素去处理即可(a元素通过target对象就可以知道事件委托方是哪个元素,从而进行不同的处理),这样就简化了程序,也避免了相互之间发生冲突的可能性。这就是事件委托。

js失焦可以用事件委托吗

可以。基于JS的事件冒泡机制从内到外,可以以JS事件委托的方式,在父元素上给子元素绑定事件,从而减少代码的复杂度。js失焦是指在JavaScript中,失去焦点事件是blur()事件。

javascript什么时候使用事件委托

通俗的讲,事件就是onclick,onmouseover,onmouseout,等就是事件,委托呢,就是让别人来做,这个事件本来是加在某些元素上的,然而你却加到别人身上来做,完成这个事件。

也就是:利用冒泡的原理,把事件加到父级上,触发执行效果。

好处呢:1,提高性能。

我们可以看一个例子:需要触发每个li来改变他们的背景颜色。

ul id="ul"

liaaaaaaaa/li

libbbbbbbb/li

licccccccc/li

/ul

window.onload = function(){

var oUl = document.getElementById("ul");

var aLi = oUl.getElementsByTagName("li");

for(var i=0; iaLi.length; i++){

aLi[i].onmouseover = function(){

this.style.background = "red";

}

aLi[i].onmouseout = function(){

this.style.background = "";

}

}

}

这样我们就可以做到li上面添加鼠标事件。

但是如果说我们可能有很多个li用for循环的话就比较影响性能。

下面我们可以用事件委托的方式来实现这样的效果。html不变

window.onload = function(){

var oUl = document.getElementById("ul");

var aLi = oUl.getElementsByTagName("li");

/*

这里要用到事件源:event 对象,事件源,不管在哪个事件中,只要你操作的那个元素就是事件源。

ie:window.event.srcElement

标准下:event.target

nodeName:找到元素的标签名

*/

oUl.onmouseover = function(ev){

var ev = ev || window.event;

var target = ev.target || ev.srcElement;

//alert(target.innerHTML);

if(target.nodeName.toLowerCase() == "li"){

target.style.background = "red";

}

}

oUl.onmouseout = function(ev){

var ev = ev || window.event;

var target = ev.target || ev.srcElement;

//alert(target.innerHTML);

if(target.nodeName.toLowerCase() == "li"){

target.style.background = "";

}

}

}

好处2,新添加的元素还会有之前的事件。

我们还拿这个例子看,但是我们要做动态的添加li。点击button动态添加li

如:

input type="button" id="btn" /

ul id="ul"

liaaaaaaaa/li

libbbbbbbb/li

licccccccc/li

/ul

不用事件委托我们会这样做:

window.onload = function(){

var oUl = document.getElementById("ul");

var aLi = oUl.getElementsByTagName("li");

var oBtn = document.getElementById("btn");

var iNow = 4;

for(var i=0; iaLi.length; i++){

aLi[i].onmouseover = function(){

this.style.background = "red";

}

aLi[i].onmouseout = function(){

this.style.background = "";

}

}

oBtn.onclick = function(){

iNow ++;

var oLi = document.createElement("li");

oLi.innerHTML = 1111 *iNow;

oUl.appendChild(oLi);

}

}

这样做我们可以看到点击按钮新加的li上面没有鼠标移入事件来改变他们的背景颜色。

因为点击添加的时候for循环已经执行完毕。

那么我们用事件委托的方式来做。就是html不变

window.onload = function(){

var oUl = document.getElementById("ul");

var aLi = oUl.getElementsByTagName("li");

var oBtn = document.getElementById("btn");

var iNow = 4;

oUl.onmouseover = function(ev){

var ev = ev || window.event;

var target = ev.target || ev.srcElement;

//alert(target.innerHTML);

if(target.nodeName.toLowerCase() == "li"){

target.style.background = "red";

}

}

oUl.onmouseout = function(ev){

var ev = ev || window.event;

var target = ev.target || ev.srcElement;

//alert(target.innerHTML);

if(target.nodeName.toLowerCase() == "li"){

target.style.background = "";

}

}

oBtn.onclick = function(){

iNow ++;

var oLi = document.createElement("li");

oLi.innerHTML = 1111 *iNow;

oUl.appendChild(oLi);

}

}

javascript onclick响应函数没有括号?

onclick是一个事件,td.onclick=ToOnClick意思是说,在td发生点击事件时,执行后面的函数(也叫委托)

所以这里不用括号

如果一定要用括号,就是另外一种写法了:

td.onclick=function(){TdOnClick();};// 这是匿名函数的写法,等你用的多了,再回顾一下也就明白了

如果确实想搞明白,可以搜索一下 Javascript 委托

了解一下委托的概念,或者参考:


当前标题:JavaScript委托,js委托事件
本文地址:http://myzitong.com/article/dsophsh.html