jQuery 綁定事件
jQuery提供了多種綁定事件的方式,每種方式各有其特點(diǎn),明白了它們之間的異同點(diǎn),有助于我們?cè)趯懘a的時(shí)候進(jìn)行正確的選擇,從而寫出優(yōu)雅而容易維護(hù)的代碼。下面我們來(lái)看下jQuery中綁定事件的方式都有哪些。
jQuery中提供了四種事件監(jiān)聽方式,分別是bind、live、delegate、on,對(duì)應(yīng)的解除監(jiān)聽的函數(shù)分別是unbind、die、undelegate、off。在開始看他們之前
一:bind(type,[data],function(eventObject))
bind是使用頻率較高的一種,作用就是在選擇到的元素上綁定特定事件類型的監(jiān)聽函數(shù),參數(shù)的含義如下:
type:事件類型,如click、change、mouseover等;
data:傳入監(jiān)聽函數(shù)的參數(shù),通過(guò)event.data取到??蛇x;
function:監(jiān)聽函數(shù),可傳入event對(duì)象,這里的event是jQuery封裝的event對(duì)象,與原生的event對(duì)象有區(qū)別,使用時(shí)需要注意
bind的源碼:
| bind: function( types, data, fn ) { return this.on( types, null, data, fn ); } $('#myol li').bind('click',getHtml); |
bind的特點(diǎn)就是會(huì)把監(jiān)聽器綁定到目標(biāo)元素上,有一個(gè)綁一個(gè),在頁(yè)面上的元素不會(huì)動(dòng)態(tài)添加的時(shí)候使用它沒什么問(wèn)題。但如果列表中動(dòng)態(tài)增加一個(gè)“列表元素5”,點(diǎn)擊它是沒有反應(yīng)的,必須再bind一次才行。要想不這么麻煩,我們可以使用live。
jQuery還有一種事件綁定的簡(jiǎn)寫方式如a.click(function(){});、a.change(function(){});等,它們的作用與bind一樣,僅僅是簡(jiǎn)寫而已。
二:live(type, [data], fn)
live的參數(shù)和bind一樣,它又有什么蹊蹺呢,我們還是先瞄一眼源碼:
| live: function( types, data, fn ) { jQuery( this.context ).on( types, this.selector, data, fn ); return this; } |
可以看到live方法并沒有將監(jiān)聽器綁定到自己(this)身上,而是綁定到了this.context上了。這個(gè)context是什么東西呢?其實(shí)就是元素的限定范圍,看了下面的代碼就清楚了:
| $('#myol li').context; //document $('#myol li','#myol').context; //document $('#myol li',$('#myol')[0]); //ol |
通常情況下,我們都不會(huì)像第三種方式那樣使用選擇器,所以也就認(rèn)為這個(gè)context通常就是document了,即live方法把監(jiān)聽器綁定到了 document上了。不把監(jiān)聽器直接綁定在元素上,你是不是想起事件委托機(jī)制來(lái)了呢?若沒有,可以點(diǎn)擊這里回憶一下。live正是利用了事件委托機(jī)制來(lái) 完成事件的監(jiān)聽處理,把節(jié)點(diǎn)的處理委托給了document。在監(jiān)聽函數(shù)中,我們可以用event.currentTarget來(lái)獲取到當(dāng)前捕捉到事件的 節(jié)點(diǎn)。下面的例子來(lái)揭曉:
新聞熱點(diǎn)
疑難解答
圖片精選