欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺析jquery某一元素重復(fù)綁定的問(wèn)題

 更新時(shí)間:2014年01月03日 09:24:39   作者:  
本篇文章主要是對(duì)jquery某一元素重復(fù)綁定的問(wèn)題進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助

某天晚上寫(xiě)代碼的時(shí)候,突然出了bug,想了很久都不知道問(wèn)題出在哪里(其實(shí)是很簡(jiǎn)單的問(wèn)題,但由于我還是個(gè)菜鳥(niǎo),所以不知道)。幾經(jīng)周折,這中間的過(guò)程就不提了,終于讓我在快崩潰的時(shí)候,發(fā)現(xiàn)了原因。原來(lái)是因?yàn)橥籮query元素可以重復(fù)綁定,當(dāng)使用了嵌套綁定的時(shí)候,就容易出錯(cuò)。如代碼:

復(fù)制代碼 代碼如下:

$('.test').bind('click',function(){
     $('.last').bind('click',function(){
          alert('nihao');
     });
});

<button class="test">上一級(jí)綁定</button>
<button class="last">下一級(jí)綁定</button>

當(dāng)我點(diǎn)擊第一個(gè)button時(shí),再點(diǎn)擊第二個(gè)button,是沒(méi)有問(wèn)題的??扇绻陧?yè)面刷新之前,點(diǎn)擊了多次(n次)第一個(gè)button的話(huà),此時(shí)再點(diǎn)擊第二個(gè)button,就出問(wèn)題了,就會(huì)彈出(n個(gè))alert對(duì)話(huà)框。

解決辦法:在會(huì)重復(fù)綁定的元素上執(zhí)行解綁,即unbind(),如:
復(fù)制代碼 代碼如下:

$('.test').bind('click',function(){
     $('.last').unbind('click').bind('click',function(){
          alert('nihao');
     });
});
 
這樣,不管點(diǎn)擊多少次第一個(gè)button,再點(diǎn)擊第二個(gè)時(shí),只會(huì)彈出一個(gè)alert對(duì)話(huà)框。

這里再介紹兩個(gè)與bind()相關(guān)聯(lián)的,one()和live()。
 
one() 方法為被選元素附加一個(gè)或多個(gè)事件處理程序,并規(guī)定當(dāng)事件發(fā)生時(shí)運(yùn)行的函數(shù)。當(dāng)使用 one() 方法時(shí),每個(gè)元素只能運(yùn)行一次事件處理器函數(shù)。通俗的講就是只管用一次。

至于live(),引用別人講的(http://www.cnblogs.com/wujilong/articles/1866834.html):
平時(shí)在使用jQuery進(jìn)行AJAX操作的時(shí)候,新生成的元素事件會(huì)失效,有時(shí)候不得不重新綁定一下事件,但是這樣做很麻煩。例如評(píng)論分頁(yè)后對(duì)評(píng)論內(nèi)容的JS驗(yàn)證會(huì)失效等。在jQuery1.3之前有一個(gè)插件會(huì)解決這個(gè)問(wèn)題http://jquery.com/ ,jQuery1.3增加了一個(gè)live()方法,下面是手冊(cè)上的說(shuō)明:

jQuery 1.3中新增的方法。給所有當(dāng)前以及將來(lái)會(huì)匹配的元素綁定一個(gè)事件處理函數(shù)(比如click事件)。也能綁定自定義事件。

目前支持 click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, keydown, keypress, keyup。

還不支持 blur, focus, mouseenter, mouseleave, change, submit

與bind()不同的是,live()一次只能綁定一個(gè)事件。

這個(gè)方法跟傳統(tǒng)的bind很像,區(qū)別在于用live來(lái)綁定事件會(huì)給所有當(dāng)前以及將來(lái)在頁(yè)面上的元素綁定事件(使用委派的方式)。比如說(shuō),如果你給頁(yè)面上所有的li用live綁定了click事件。那么當(dāng)在以后增加一個(gè)li到這個(gè)頁(yè)面時(shí),對(duì)于這個(gè)新增加的li,其click事件依然可用。而無(wú)需重新給這種新增加的元素綁定事件。

.live()與流行的liveQuery插件很像,但有以下幾個(gè)主要區(qū)別:

•.live 目前只支持所有事件的子集,支持列表參考上面的說(shuō)明。
•.live 不支持liveQuery提供的“無(wú)事件”樣式的回調(diào)函數(shù)。.live只能綁定事件處理函數(shù)。
•.live 沒(méi)有”setup”和”cleanup”的過(guò)程。因?yàn)樗械氖录俏啥皇侵苯咏壎ㄔ谠厣系摹?/P>

要移除用live綁定的事件,請(qǐng)用die方法

用法示例:
<div class=”myDiv”></div>

jquery:
$(“.myDiv”).live(“click”, function(){
alert(“clicked!”);
});

如果使用javascript動(dòng)態(tài)創(chuàng)建一個(gè)class為mydiv的元素,點(diǎn)擊元素依然會(huì)有彈出。為什么使用live后就有了呢?這是因?yàn)閖query利用了事件的冒泡機(jī)制,直接把事件綁定在了document上,然后通過(guò)event.target找出事件的來(lái)源。這跟jquery.livequery插件不一樣,jquery.livequery每20毫秒做一次檢查,如有新生成則重新綁定一次事件。

使用live當(dāng)然有利也有弊:

好處就是:元素更新時(shí)不用反復(fù)去定義事件。
壞處就是:把事件綁定在document上會(huì)在頁(yè)面上每一個(gè)元素都呼叫一次,如使用不當(dāng)會(huì)嚴(yán)重影響性能。而且不支持blur, focus, mouseenter, mouseleave, change, submit。

相關(guān)文章

最新評(píng)論