亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

jQuery中的.bind()、.live()和.delegate()分析

系統 2759 0

首先,可視化一個 HMTL 文檔的 DOM 樹是很有幫助的。一個簡單的 HTML 頁面看起來就像是這個樣子:

?

jQuery中的.bind()、.live()和.delegate()分析

?

事件冒泡 ( 又稱事件傳播 ) 當我們點擊一個鏈接時,其觸發了鏈接元素的單擊事件,該事件則引發任何我們已綁定到該元素的單擊事件上的函數的執行。 利用事件傳播(這里是冒泡)這個機制,就可以實現事件委托。具體來說,事件委托就是事件目標自身不處理事件,而是把處理任務委托給其父元素或者祖先元素,甚至根元素(document

?

?

一個單擊操作會觸發 alert 函數的執行。 click 事件接著會向樹的根方向傳播,廣播到父元素,然后接著是每個祖先元素,只要是它的某個后代元素上的單擊事件被觸發,事件就會傳給它 ,在操縱 DOM 的語境中, document 是根節點。

jQuery中的.bind()、.live()和.delegate()分析

?

現在我們再來說明 .bind() .live() .delegate() 的不同之處

.bind()

這是最簡單的綁定方法了。 JQuery 掃描文檔找出所有的 $(' a') 元素,并把 alert 函數綁定到每個元素的 click 事件上。 注:其隱含意思,.bind() 只能給調用它的時候已經存在的元素綁定事件,不能給未來新增的元素綁定事件 。如果是Ajax 過來的元素則無能為力,但是其勝在效率高

?

?

.live()?

?

JQuery alert 函數綁定到 $(document) 元素上,并使用 'click' 'a' 作為參數。任何時候只要有事件冒泡到 document 節點上,它就查看該事件是否是一個 click 事件,以及該事件的目標元素與 'a' 這一 CSS 選擇器是否匹配,如果都是的話,則執行函數。 jQuery 1.4 開始支持在使用 .live() 方法時配合使用一個上下文參數:


?

?

.delegate()?

?

JQuery 掃描文檔查找 $('#container') ,并使用 click 事件和 'a' 這一 CSS 選擇器作為參數把 alert 函數綁定到 $('#container') 上。任何時候只要有事件冒泡到 $('#container') 上,它就查看該事件是否是 click 事件,以及該事件的目標元素是否與 CSS 選擇器相匹配。如果兩種檢查的結果都為真的話,它就執行函數。 (注:如果監聽父控件被移除,其響應事件也會失效)可見,.delegate()方法是一個相對完美的解決方案。但在DOM結構簡單的情況下,也可以使用.live()。

?

1、 這句話是否正確?

? ?不完全正確,

?

如上面的代碼,后者實際上要快過前者,因為前者首先要掃描整個的文檔查找所有的 $(‘a') 元素,把它們存成 jQuery 對象。盡管 live 函數僅需要把 'a' 作為串參數傳遞以用做之后的判斷,但是 $() 函數并未 知道 被鏈接的方法將會是 .live() 。而另一方面, delegate 方法僅需要查找并存儲 $(document) 元素。 一種解決的辦法為,使用一種“早委托”的方式,如下:

?

在此,(function($){ })(jQuery) 是一個“立即執行的匿名函數”,構成了一個閉包,可以防止命名沖突。在匿名函數內部, $ 參數引用 jQuery 對象。這個匿名函數不會等到 DOM 就緒就會執行。 注意,使用這個hack 時,腳本必須是在頁面的 head 元素中執行的 ,意味著在 $(document).reday()之外執行 。之所以選擇這個時機,因為這時候剛好document 元素可用,而整個 DOM 還遠未生成;如果把腳本放在結束的 body 標簽前面,就沒有意義了,因為那時候 DOM 已經完全可用了。

?

?

2、.live() 相比 .delegate() 缺點有哪些?

??一、$() 函數會找到當前頁面中選擇器匹配元素并創建 jQuery 對象,但在確認事件目標時卻不用這個元素集合,而是使用選擇符表達式與 event.target 或其祖先元素進行比較,因而生成這個 jQuery 對象會造成不必要的開銷;

??二、默認把事件綁定到$(document) 元素,如果 DOM 嵌套結構很深,事件冒泡通過大量祖先元素會導致性能損失;

??三、只能放在直接選擇的元素后面,不能在連綴的DOM 遍歷方法后面使用,即 $( #infotable?td ).live …可以,但 $(“#infotable ).find( td ).live …不行;

??四、收集選擇器匹配元素并創建jQuery 對象,但實際操作的卻是 $(document) 對象,令人費解。

?

3、.live() 真的綁定在 document 上面嗎?

???可以絕對的肯定。寫一個樣例,html 代碼為:

? 測試代碼:

?

其測試結果為:?ccc?>?aaa?>?bbb,和預期相符合

jQuery中的.bind()、.live()和.delegate()分析


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲久久视频 | 欧美精品在线一区二区三区 | 中文字幕亚洲综合精品一区 | 国产国语videosex另类 | 五月天色中色 | 免费看成人毛片日本久久 | 久久视精品 | 国产成人精品视频播放 | 色人阁网站 | 99国产精品久久久久久久日本 | 国产成人免费不卡在线观看 | 中文精品久久久久国产网站 | 天天透天天操 | 久久人人澡 | 国产精品18久久久久网站 | 深夜在线看 | 国产成年女一区二区三区 | 抱着cao才爽视频 | 国产在线视频你懂得 | 国产麻豆免费 | 日本在线看片网站 | 干天天| 美女被a到爽视频在线观看 美女被cao的视频免费看 | 欧美日韩视频在线第一区 | 亚洲专区在线视频 | 欧美综合亚洲图片综合区 | 国产尤物福利视频在线观看 | 韩国高清不卡一区二区 | 免费在线观看黄色小视频 | 年级的后妈妈2中文翻译 | 操美女国产 | 国产在线精品观看一区 | 四虎免费大片aⅴ入口 | 亚洲香蕉一区二区三区在线观看 | 天天天天天天操 | 神马我不卡在线观看 | 人人干人人舔 | 亚洲一区二区三区播放在线 | 人人干天天干 | 国产乱子伦| 欧美日韩一区二区高清视 |