国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery綁定自定義事件的魔法升級版

2019-11-20 09:34:53
字體:
來源:轉載
供稿:網友

jQuery綁定自定義事件

首先讓我們來看看jQuery綁定自定義事件的使用方法,你可以使用bind或者live來訂閱一個事件(當然1.7以后也可以使用on了),代碼如下:

$("#myElement").bind('customEventName',function(e){ ... });$(".elementsClass").live('customEventName',function(e){ ... });

然后通過如下方式來觸發事件:

$("#myelement").trigger('customEventName');

或者你也可以為自定義事件增加額外的參數,樣例如下:

$("#myelement").bind('customEventName',function(e,data){ if(data.custom) ... });$("#myelement").trigger('customEventName',{ custom: false });

魔法升級

所謂魔法升級,其實是想讓整個程序所有的自定義事件能夠自動注冊并綁定jQuery上,然后執行的時候,所有注冊該事件的模塊都會執行。比如模塊User.js里定義的UserUpdate方法和Blogs.js里定義的BlogUpdate方法都定義了在發布一篇博客的時候需要執行的function函數,整個時候我們可以通過注冊統一的事件名稱(例如BlogAdded)bind到jQuery指定的一個容器上(例如document)上,然后發布博客成功以后,執行$(document).trigger("BlodAdded")就OK了。

下面我們給個通用的樣例代碼:

var components = [User, Blog, Group, Friend, Topic, Photo];var eventTypes = ["AddComplete", "UpdateComplete", "DeleteComplete", "LockComplete", "UnLockComplete"];$.each(components, function(i,component) { $.each(eventTypes, function(i,eventType) {  var handler = component[eventType];  if (handler) $(document).bind(eventType, handler); });}) 

然后每個js模塊定義的代碼安裝如下格式:

User= { AddComplete: function(e, data) { //... }, UpdateComplete: function(e, data) { //... }} 
 

這樣,不管在任何地方,如果我們需要的話,就可以使用jQuery的方式來觸發我們的事件了:

$(document).trigger("UpdateComplete", data); 

通過這種方法,大家可以發現一個模塊的method只能注冊一個事件,那如果我們通過一個方法來注冊多個事件觸發的話,可以使用如下方式:

var blogController = { blogAddOrUpdateComplete: function() { //... }}blogController.blogAddComplete = blogController.blogUpdateComplete = blogController.blogAddOrUpdateComplete; 

最后注意:本文只是展示一個簡單的例子,不要混用不同module同一事件名稱的用法哦,比如,User.js里的AddComplete和Blog.js里的AddComplete可能根本就沒有關系,也就是說只處理自己相應的邏輯,這時候,就不應該統一處理這個事件,但如果要檢測的東西是一樣的話,就可以使用,比如DisableUserComplete,就可以通用,因為User模塊需要處理禁用賬戶以后的操作,Blog模塊可能也需要處理禁用賬戶以后的操作。

以上就是本文的全部內容,了解更多jQuery的語法,大家可以查看:《jQuery 1.10.3 在線手冊》,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 海伦市| 裕民县| 西乌珠穆沁旗| 临江市| 临澧县| 三门县| 达拉特旗| 竹山县| 通许县| 肥东县| 泸定县| 天峻县| 石棉县| 开封市| 佛教| 都兰县| 吉林市| 科技| 信宜市| 泸西县| 马鞍山市| 镇沅| 阜阳市| 上犹县| 南丰县| 临桂县| 镇康县| 江北区| 神池县| 宝丰县| 贵州省| 怀集县| 工布江达县| 富源县| 南皮县| 高安市| 大名县| 兰西县| 达尔| 博野县| 凤城市|