讀jQuery之十 事件模塊概述
雖然事件模塊代碼很難讀,但其提供的API接口還是很清晰的。如下

1 添加事件(bind/one/live/delegate/hover/toggle)
bind 基本的添加事件函數(shù)。
one 添加只執(zhí)行一次的事件函數(shù)。
live 事件代理(使用document代理)。
delegate 事件代理(使用指定元素代理)。
hover 模擬css的hover。
toggle 顯示/隱藏。
bind/one/live 都是使用內(nèi)部的jQuery.event.add 來完成事件添加。
delegate 內(nèi)部調(diào)用的是live。
hover 內(nèi)部使用mouseenter/mouseleave,而mouseenter/mouseleave又使用bind。
toggle 內(nèi)部使用click,而click內(nèi)部又調(diào)用的是bind。
實際上jQuery的一個each調(diào)用就給jQuery對象上增加了24個添加事件的快捷方法
如下圖
如下圖
記住,bind調(diào)用的是jQuery.event.add,因此 jQuery.event.add 才是整個jQuery添加事件模塊的核心。以上所有的方法都是在其之上構建的上層應用。如圖
2 刪除事件 (unbind/die/undelegate)
unbind 刪除事件基礎方法??梢詣h除一個指定handler,還可以刪除某類型事件的全部handler,甚至可以刪除掛在element上的全部事件。其內(nèi)部調(diào)用jQuery.event.remove。
die/undelegate 刪除事件代理。 內(nèi)部都使用unbind。
因此, jQuery.event.remove 才是整個jQuery刪除事件模塊的核心。unbind/die/undelegate都是在其之上構建的上層應用。如圖
3 觸發(fā)事件(trigger/triggerHandler)
trigger 觸發(fā)一個事件(會冒泡)
triggerHandler 觸發(fā)一個事件(不會冒泡)
trigger/triggerHandler 內(nèi)部調(diào)用的都是jQuery.event.trigger,因此jQuery.event.trigger 才是整個jQuery觸發(fā)事件模塊的核心。如圖
相關文章
jQuery實現(xiàn)的checkbox級聯(lián)選擇下拉菜單效果示例
這篇文章主要介紹了jQuery實現(xiàn)的checkbox級聯(lián)選擇下拉菜單效果,涉及jQuery鼠標事件響應及表格table動態(tài)操作的相關技巧,需要的朋友可以參考下2016-12-12jquery popupDialog 使用 加載jsp頁面的方法
下面小編就為大家?guī)硪黄猨query popupDialog 使用 加載jsp頁面的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10jquery實現(xiàn)LED廣告牌旋轉(zhuǎn)系統(tǒng)圖片切換效果代碼分享
這篇文章主要介紹了jquery實現(xiàn)LED廣告牌旋轉(zhuǎn)系統(tǒng)圖片切換效果類似路邊場景,很實用的代碼,推薦給大家,有需要的小伙伴可以參考下。2015-08-08與jquery serializeArray()一起使用的函數(shù),主要來方便提交表單
與jquery serializeArray()一起使用的函數(shù),主要來方便提交表單,需要的朋友可以參考下。2011-01-01