美文网首页
事件委托

事件委托

作者: 孤岛上的叶子 | 来源:发表于2019-08-05 16:29 被阅读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);

        }

    }

    相关文章

      网友评论

          本文标题:事件委托

          本文链接:https://www.haomeiwen.com/subject/bgbmdctx.html