jQuery中bind,live,delegate,on绑定事件的方式与区别

jQuery中提供了四种事件监听方式,分别是bind、live、delegate、on,对应的解除监听的函数分别是unbind、die、undelegate、off。函数

已知有4个列表元素:this

  列表元素1对象

 

  列表元素2seo

 

  列表元素3事件

 

   列表元素4get

 

  一、bind源码

bind(type,[data],function(eventObject))io

bind是使用频率较高的一种,做用就是在选择到的元素上绑定特定事件类型的监听函数,参数的含义以下:event

type:事件类型,如click、change、mouseover等;function

data:传入监听函数的参数,经过event.data取到。可选;

function:监听函数,可传入event对象,这里的event是jQuery封装的event对象,与原生的event对象有区别,使用时须要注意。

  源码:

bind: function( types, data, fn ) {

return this.on( types, null, data, fn );

}

  能够看到内部是调用了on方法。

  bind的特色就是会把监听器绑定到目标元素上,有一个绑一个,在页面上的元素不会动态添加的时候使用它没什么问题。但若是列表中动态增长一个“列表元素5”,点击它是没有反应的,必须再bind一次才行。

  

  二、live

live(type, [data], fn)

live的参数和bind同样,它又有什么蹊跷呢,咱们仍是先瞄一眼源码:

live: function( types, data, fn ) {

jQuery( this.context ).on( types, this.selector, data, fn );

return this;

}

能够看到live方法并无将监听器绑定到本身(this)身上,而是绑定到了this.context上了。

live正是利用了事件委托机制来完成事件的监听处理,把节点的处理委托给了document。

使用事件委托的优势一目了然,新添加的元素没必要再绑定一次监听器。

 

  三、delegate

将监听事件绑定在就近的父级元素上,源码:

delegate: function( selector, types, data, fn ) {

return this.on( types, selector, data, fn );

}

这下,咱们的选择又多了一些灵活性,不单能够利用事件委托,还能够选择委托的对象。毕竟老麻烦同一我的帮忙很很差嘛。对于如何选择委托对象,仍是须要必定的策略的,毕竟父级元素能够有不少。我以为原则应该是选择最近的“稳定”元素,选择最近是由于事件能够更快的冒泡上去,可以在第一时间进行处理。所谓“稳定”是指该父级元素是一开始就在页面上的,不是动态添加上来的,并且未来也不会消失掉,这样能够保证它能够时时监控着本身的孩子。

 

  四、on

on(type,[selector],[data],fn)

参数与delegate差很少但仍是有细微的差异,首先type与selector换位置了,其次selector变为了可选项。

$('#myol li').on('click',getHtml);

能够看到event.currentTarget是li本身,与bind的效果同样。至于传selector进去,就是跟delegate同样的意义了,除了参数顺序不一样,其余彻底同样。

相关文章
相关标签/搜索