美文网首页饥人谷技术博客
jQuery绑定事件与事件代理

jQuery绑定事件与事件代理

作者: fanison | 来源:发表于2019-03-31 11:56 被阅读46次

在1.7之前的版本中jQuery处理事件有多个方法:live、bind、degelate(作用各不相同)。后来统一的使用on/off方法

.on()

.on( events [,selector ] [,data ], handler(eventObject) )

  • events:一个或多个空格分隔的事件类型和可选的命名空间,或仅仅是命名空间,比如"click", "keydown.myPlugin", 或者 ".myPlugin"

  • selector:一个选择器字符串,用于过滤出被选中的元素中能触发事件的后代元素。如果选择器是 null 或者忽略了该选择器,那么被选中的元素总是能触发事件

  • data:当一个事件被触发时,要传递给事件处理函数的event.data

  • handler(eventObject):事件被触发时,执行的函数。若该函数只是要执行return false的话,那么该参数位置可以直接简写成 false

<div class="box">
  <ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
  </ul>
</div>
<input id="ipt" type="text"> <button id="btn">添加</button>
<div id="wrap">
</div>

绑定事件:

  $('ul li').on('click',function(){
    console.log($(this).text())    //点击输出
  })  
on

新增元素

$('#btn').on('click', function(){
  var value = $('#ipt').val()      //获取input值
  $('.box>ul').append('<li>'+value+'</li>')      //ul新增li,value为input值
})
新增

查看绑定事件对新增元素是否生效


未生效

可以清楚的看到我们直接给li添加事件,会导致后来新增的DOMli点击没有效果,这个和javaScript的点击事件和事件代理是一样,可以使用事件代理来处理这个点击事件

//事件代理
$('.box ul').on('click', 'li', function(){
  console.log($(this).text());
})
//上面代码相当于原生 js 的
document.querySelector('.box ul').addEventListener('click', function(e){
    if(e.target.tagName.toLowerCase() === 'li'){
        //do something
    }
})
事件代理

.off()

.off( events [, selector ] [, handler ] )

移除一个事件处理函数

$('.box li').off('click')

相关文章

  • jQuery事件

    1、jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用 jquery在1.7版本之前绑定事件可通过bi...

  • jQuery 动画

    jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用 使用.on( events [,selector ...

  • jQuery事件

    一、jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用 .on( events [,selector ...

  • jQuery事件绑定

    jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用 在1.7之前的版本中jQuery处理事件有多个方法...

  • jQuery绑定事件与事件代理

    在1.7之前的版本中jQuery处理事件有多个方法:live、bind、degelate(作用各不相同)。后来统一...

  • 03-jQuery事件相关

    事件绑定与解绑 jQuery中有两种绑定事件方式eventName(fn);编码效率略高/部分事件jQuery没有...

  • Jquery day_3

    1.1 Jquery 事件注册 1.2 jquery 事件处理 on(): 用于事件绑定,目前最好用的事件绑定方...

  • jquery对节点的操作

    Jquery对事件的绑定 $().bind(“事件类型”, 事件处理); 给jquery绑定一个事件$().bi...

  • jquery事件

    jQuery其他事件 绑定事件 自定义事件

  • jQuery中绑定事件时bind和on的区别

    jquery的bind跟on绑定事件的区别:主要是事件冒泡;jquery文档中bind和on函数绑定事件的用法: ...

网友评论

    本文标题:jQuery绑定事件与事件代理

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