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同样的意义了,除了参数顺序不一样,其余彻底同样。