美文网首页
jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用

jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用

作者: 东郭皮蛋 | 来源:发表于2019-03-09 21:02 被阅读0次

事件绑定

事件处理中最头疼的就是浏览器兼容问题,jQuery封装了很好的API,可以方便的进行事件处理

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

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

看起来参数及其复杂,我们看一下各个参数的意思

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

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

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

  4. 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>

<script>
$('.box li').on('click', function(){
    console.log(1)
  var str = $(this).text()
  $('#wrap').text(str)
})

//等同于
$('.box>ul>li').click(function(){
    console.log(2)
  var str = $(this).text()
  $('#wrap').text(str)
})

//也可以这样写
$('.box li').on('click.hello', function(){
    console.log(3)
  var str = $(this).text()
  $('#wrap').text(str)
})
//命名空间没什么特别的作用,只不过在解绑事件时便于区分绑定的事件
$('.box li').off('click.hello')

//可是用如下方法新增的元素是没绑定事件的
$('#btn').on('click', function(){
  var value = $('#ipt').val()
  $('.box>ul').append('<li>'+value+'</li>')
})

//我们可以用事件代理
$('.box ul').on('click', 'li', function(){
  var str = $(this).text()
  $('#wrap').text(str)
})

//上面代码相当于原生 js 的
document.querySelector('.box ul').addEventListener('click', function(e){
    if(e.target.tagName.toLowerCase() === 'li'){
        //do something
    }
})

//绑定事件的时候我们也可以给事件附带些数据,只不过这种用法很少见
$('.box').on('click', {name: 'hunger'}, function(e){
    console.log(e.data)
})

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

同 on,绑定事件,但只执行一次

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

移除一个事件处理函数

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

.trigger( eventType [, extraParameters ] )

根据绑定到匹配元素的给定的事件类型执行所有的处理程序和行为

$('#foo').on('click', function() {
  console.log($(this).text())
});
$('#foo').trigger('click')

直接绑定和使用事件代理

  • 直接绑定
    示例:
<script src="//code.jquery.com/jquery-1.9.1.min.js"></script>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
  <ul>
    <li>1</li>
    <li>2</li>
    <li>3</li>
  </ul>
  <input type="text">
  <button>添加</button>

  <script>
  $('ul li').on('click',function(){
    console.log($(this).text())
  })
  $('button').on('click',function(){
    var str = $('input').val() //获取input的值
    var li1 = $('<li>'+ str + '</li>'); //新建li 接收 input的值
    li1.appendTo('ul')  //将li添加到队列中去
  })
</script>

效果:

image

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

$('ul').on('click','li',function(){  // 选中ul 下的 li
  console.log($(this).text())
})
 $('button').on('click',function(){
    var str = $('input').val() //获取input的值
    var li1 = $('<li>'+ str + '</li>'); //新建li 接收 input的值
    li1.appendTo('ul')  //将li添加到队列中去
  })

效果:

image

给ul绑定事件,选中ul下的li 可以查看上面的绑定事件的on方法 下的

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

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

相关文章

  • jQuery 动画

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

  • jQuery事件

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

  • jQuery事件

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

  • jQuery事件绑定

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

  • 20:jQuery事件

    jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用 //ps:两种方式内存消耗相差很多。明显第二种使用...

  • jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用

    jquery 如何绑定事件 事件处理中最头疼的就是浏览器兼容问题,jQuery封装了很好的API,可以方便的进行事...

  • jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用

    事件绑定 事件处理中最头疼的就是浏览器兼容问题,jQuery封装了很好的API,可以方便的进行事件处理 在1.7之...

  • jquery入门(3)

    4.jQuery中的事件绑定 #4.1.事件绑定 on方法绑定 直接绑定 总结:事件里面的this是原生的this...

  • JQuery学习笔记(一)

    学习目标 掌握使用jQuery操作样式 掌握使用jQuery操作DOM 能使用jQuery绑定事件 能使用jQue...

  • JS操作html元素中的事件

    事件在日常使用到事件,比如:按钮的点击,鼠标的点击等,那么如何给一个元素绑定事件呢,事件的绑定有几个方式呢? 绑定...

网友评论

      本文标题:jquery 如何绑定事件?直接绑定和使用事件代理分别如何使用

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