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

首頁 > 編程 > JavaScript > 正文

jQuery中綁定事件的命名空間詳解

2019-11-20 23:52:27
字體:
供稿:網(wǎng)友
在沒有看到這篇 文章之前,我一直不知道原來bind也可以有命名空間。事實上,我看完這篇文章后,再去翻了一下手冊,也才發(fā)現(xiàn)了一點點的注釋。但手冊也僅僅是一句話就帶 過去了。沒有過多的深究,或許他認為命名空間這玩意很簡單,沒有必要多解釋?

先看手冊,由于bind方法有三個參數(shù)(type,[data],fn),所以手冊上這么介紹:

.bind() 方法是用于往文檔上附加行為的主要方式。所有JavaScript事件對象, 比如focus, mouseover, 和 resize,都是可以作為type參數(shù)傳遞進來的。

jQuery還提供了一些綁定這些標準事件類型的簡單方式,比如.click()用于簡 化.bind('click')。一共有以下這 些:blur, focus, focusin, focusout, load, resize, scroll, unload, click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress, keyup, error 。

任何作為type參數(shù)的字符串都是合法的;如果一個字符串不是原生的JavaScript事件名, 那么這個事件處理函數(shù)會綁定到一個自定義事件上。這些自定義事件絕對不會由瀏覽器觸發(fā),但可以通過使用.trigger()或 者.triggerHandler()在其他代碼中手動觸發(fā)。

如果type參數(shù)的字符串中包含一個點(.)字符, 那么這個事件就看做是有命名空間的了。這個點字符就用來分隔事件和他的命名空間。舉例來說,如果執(zhí) 行 .bind('click.name', handler) ,那么字符串中的 click 是事件類型,而字符串 name 就是命名空間。命名空 間允許我們?nèi)∠壎ɑ蛘哂|發(fā)一些特定類型的事件,而不用觸發(fā)別的事件。參考unbind()來獲取更多信息。

當一個事件傳到一個元素上,所有綁定在上面的針對哪個事件的處理函數(shù)都會觸發(fā)。如果注冊了多個事件 處理函數(shù),總是按照綁定的順序依次觸發(fā)。當所有綁定的事件處理函數(shù)執(zhí)行完畢后,事件繼續(xù)沿著普通的事件冒泡途徑上浮。



jQuery的 bind / unbind 方法應該說使用很簡單,而且大多數(shù)時候 可能并不會用到,取而代之的是直接用 click / keydown 之類的事件名風格的方法來做事件綁定操作。

但假設如下情況:需要在運行時根據(jù)用戶交互的結(jié)果進行不同click事件處理邏輯的綁定,因而理論 上會無數(shù)次對某一個事件進行 bind / unbind 操作。但又希望 unbind 的時候只把自己綁上去的處理邏輯給釋放掉而不是所有其他地方有 可能的額外的同一事件綁定邏輯。

這時候如果直接用 .click() / .bind('click') 加 上 .unbind('click') 來進行重復綁定的話,被 unbind 掉的將是所有綁定在元素上的 click 處理邏輯,潛在會影響到該元素 其他第三方的行為。當然如果在bind的時候是顯示定義了function變量的話,可以在unbind的時候提供 function作為第二個參數(shù)來指 定只unbind其中一個處理邏輯,但實際應用中很可能會碰到各種進行匿名函數(shù)綁定的情況。

對于這種問題,jQuery的解決方案是使用事件綁定的命名空間。即在事件名稱后添 加 .something 來區(qū)分自己這部分行為邏輯范圍。

比如 用 .bind('click.myCustomRoutine',function(){...}); 同樣是把匿名函數(shù)綁定到 click 事件(你 可以用自己的命名空間多次綁定不同的行為方法上去),當unbind的時候用 .unbind('click.myCustomRoutine') 即可 釋放所有綁定到 .myCustomRoutine 命名空間的 click 事件,而不會解除其他通過 .bind('click') 或另外的命名 空間所綁定的事件行為。

同時,使用命令空間還可以讓你一次性 unbind 所有此命名空間下的自定義事件綁定,通 過 .unbind('.myCustomRoutine') 即可。

要注意的是,jQuery的命名空間并不支持多級空間。因為在jQuery里面,如果 用 .unbind('click.myCustomRoutine.myCustomSubone') ,解除的是命名空間分別 為 myCustomRoutine 和 myCustomSubone 的兩個并列命名空間下的所有 click 事件,而不 是 "myCustomRoutine 下的 myCustomSubone 子空間"。

jQuery的 bind / unbind 方法應該說使用很簡單,而且大多數(shù)時候可能并不會用到,取而代之的是直接用 click / keydown 之類的事件名風格的方法來做事件綁定操作。

但假設如下情況:需要在運行時根據(jù)用戶交互的結(jié)果進行不同click事件處理邏輯的綁定,因而理論上會無數(shù)次對某一個事件進行 bind / unbind 操作。但又希望 unbind 的時候只把自己綁上去的處理邏輯給釋放掉而不是所有其他地方有可能的額外的同一事件綁定邏輯。

這時候如果直接用 .click() / .bind('click') 加上 .unbind('click') 來進行重復綁定的話,被 unbind 掉的將是所有綁定在元素上的 click 處理邏輯,潛在會影響到該元素其他第三方的行為。當然如果在bind的時候是顯示定義了function變量的話,可以在unbind的時候提供function作為第二個參數(shù)來指定只unbind其中一個處理邏輯,但實際應用中很可能會碰到各種進行匿名函數(shù)綁定的情況。

對于這種問題,jQuery的解決方案是使用事件綁定的命名空間。即在事件名稱后添加 .something 來區(qū)分自己這部分行為邏輯范圍。

比如用 .bind('click.myCustomRoutine',function(){...}); 同樣是把匿名函數(shù)綁定到 click 事件(你可以用自己的命名空間多次綁定不同的行為方法上去),當unbind的時候用 .unbind('click.myCustomRoutine') 即可釋放所有綁定到 .myCustomRoutine 命名空間的 click 事件,而不會解除其他通過 .bind('click') 或另外的命名空間所綁定的事件行為。

同時,使用命令空間還可以讓你一次性 unbind 所有此命名空間下的自定義事件綁定,通過 .unbind('.myCustomRoutine') 即可。

要注意的是,jQuery的命名空間并不支持多級空間。因為在jQuery里面,如果用 .unbind('click.myCustomRoutine.myCustomSubone') ,解除的是命名空間分別為 myCustomRoutine 和 myCustomSubone 的兩個并列命名空間下的所有 click 事件,而不是 "myCustomRoutine 下的 myCustomSubone 子空間"。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 东山县| 潼南县| 黔南| 磐安县| 凤台县| 海丰县| 琼海市| 色达县| 应城市| 南和县| 台前县| 永康市| 迁安市| 康乐县| 尼木县| 思茅市| 海阳市| 龙山县| 蒲城县| 时尚| 盘山县| 濉溪县| 保亭| 荆州市| 拉萨市| 满洲里市| 张家口市| 宝清县| 织金县| 万州区| 浦北县| 娄底市| 七台河市| 建宁县| 六安市| 保山市| 泰宁县| 渝中区| 西乌| 静安区| 手机|