事件委托

2019-08-05  本文已影响0人  孤岛上的叶子

事件委托也称事件代理。

这里举一个例子:有三个同事预计会在周一收到快递。为签收快递,有两种办法:一是三个人在公司门口等快递;二是委托给前台代为签收。现实当中,我们大都采用委托的方案(公司也不会容忍那么多员工站在门口就为了等快递)。前台收到快递后,她会判断收件人是谁,然后按照收件人的要求签收。这种方案还有一个优势,那就是即使公司里来了新员工,前台也会在收到寄给新员工的快递后核实并代为签收

这里其实还有2层意思:

第一,现在委托前台的同事是可以代为签收的,即程序中的现有的dom节点是有事件的;

第二,新员工也是可以被前台代为签收的,即程序中新添加的dom节点也是有事件的。

原理:事件委托是利用事件的冒泡原理来实现的,事件冒泡就是事件从最深的节点开始,然后逐步向上传播事件。比如:页面上有这么一个节点树,div>ul>li>a;比如给最里面的a加一个click点击事件,那么这个事件就会一层一层的往外执行,执行顺序a>li>ul>div,有这样一个机制,那么我们给最外面的div加点击事件,那么里面的ul,li,a做点击事件的时候,都会冒泡到最外层的div上,所以都会触发,这就是事件委托,委托它们父级代为执行事件。

实现

css:

ul{

    background: yellow;

}  

li{

    border: 1px solid gray;

    width: 500px;

    height: 30px;

}

html:

<ul>

    <li>0</li>

    <li>1</li>

    <li>2</li>

    <li>3</li>

    <li>4</li>

    <li>5</li>

    <li>6</li>

    <li>7</li>

</ul>

js:

var ul = document.getElementsByTagName("ul")[0];   

//var ul = document.querySelector("ul");

/*

var lis = document.querySelectorAll("li");

var len = lis.length;

for(var i=0; i<len; i++){

    lis[i].onclick= function(){

        ul.removeChild(this);

    }

}

*/

// 事件委托

ul.onclick= function(event){

    var evt= event|| window.event;

    var tar= evt.target || evt.srcElement; // 鼠标所点击的目标元素

    console.log( tar );

    console.log( this );

    console.log( tar.nodeName );

    if( tar.nodeName.toUpperCase() == "LI" ){

        ul.removeChild(tar);

    }

}

上一篇下一篇

猜你喜欢

热点阅读