- 87浏览
- 2022-10-24
jQuery
提供了多种绑定事件的方式,每种方式各有其特点,明白了它们之间的异同点,有助于我们在写代码的时候进行正确的选择,从而写出优雅而容易维护的代码。下面我们来看下jQuery中绑定事件的方式都有哪些。
jQuery
中提供了四种事件监听方式,分别是bind、live、delegate、on
,对应的解除监听的函数分别是unbind、die、undelegate、off
。
一:bind(type,[data],function(eventObject))
bind
是使用频率较高的一种,作用就是在选择到的元素上绑定特定事件类型的监听函数,参数的含义如下:
type
:事件类型,如click
、change
、mouseover
等;
data
:传入监听函数的参数,通过event.data
取到。可选;
function
:监听函数,可传入event
对象,这里的event
是jQuery
封装的event
对象,与原生的event
对象有区别,使用时需要注意
bind的源码:
bind: function( types, data, fn ) { return this.on( types, null, data, fn ); } $('#myol li').bind('click',getHtml);
bind的特点就是会把监听器绑定到目标元素上,有一个绑一个,在页面上的元素不会动态添加的时候使用它没什么问题。但如果列表中动态增加一个“列表元素5”,点击它是没有反应的,必须再bind一次才行。要想不这么麻烦,我们可以使用live。
jQuery还有一种事件绑定的简写方式如a.click(function(){});、a.change(function(){});等,它们的作用与bind一样,仅仅是简写而已。
二:live(type, [data], fn)
源码
live: function( types, data, fn ) { jQuery( this.context ).on( types, this.selector, data, fn ); return this; }
可以看到live方法并没有将监听器绑定到自己(this)身上,而是绑定到了this.context上了。这个context是什么东西呢?其实就是元素的限定范围,看了下面的代码就清楚了:
$('#myol li').context; //document $('#myol li','#myol').context; //document $('#myol li',$('#myol')[0]); //ol
通常情况下,我们都不会像第三种方式那样使用选择器,所以也就认为这个context通常就是document了,即live方法把监听器绑定到了 document上了。不把监听器直接绑定在元素上,你是不是想起事件委托机制来了呢?若没有,可以点击这里回忆一下。live正是利用了事件委托机制来 完成事件的监听处理,把节点的处理委托给了document。在监听函数中,我们可以用event.currentTarget来获取到当前捕捉到事件的 节点。下面的例子来揭晓:
$('#myol li').live('click',getHtml);
三:delegate
live存在那样的缺点,所以我们就思考,既然老爷子负担那么重,可不可以别把监听器绑定在document上呢,绑定在就近的父级元素上不就好了。
源码
delegate: function( selector, types, data, fn ) { return this.on( types, selector, data, fn ); }
又是调用了on,并且把selector传给了on。看来这个on真的是举足轻重的东西。照样先不管它。看看示例先:
$('#myol').delegate('li','click',getHtml);
四:on()事件绑定
① 使用on进行单事件绑定
$("button").on("click",function(){ $(this) 取到当前调用事件函数的对象
console.log($(this).html()); });
② 使用on同时为多个事件,绑定同一函数
$("button").on("mouseover click",function(){ console.log($(this).html()) });
③ 调用函数时,传入自定义参数
$("button").on("click",{name:"jianghao"},function(event){ // 使用event.data.属性名 找到传入的参数 console.log(event.data.name); })
④ 使用on进行多事件多函数绑定
$("button").on({ click:function(){ console.log("click") }, mouseover:function(){ console.log("mouseOver") } });
⑤ 使用on进行事件委派
将原本需要绑定到某元素上的事件,改为绑定在父元素乃至根节点上,然后委派给当前元素生效;
eg:$("p").click(function(){}); $(document).on("click","p",function(){});
作用:
默认的绑定方式,只能绑定到页面初始时已有的p元素,当页面新增p元素时,无法绑定到新元素上;
使用事件委派方式,当页面新增元素时,可以为所有新元素绑定事件
版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。