JS 控件事件小結(jié)
更新時(shí)間:2012年10月31日 14:57:23 作者:
事件對(duì)于控件來說至關(guān)重要,控件的消息通信機(jī)制使用事件的成本最低,但是對(duì)于JS控件來說有一些麻煩需要解決,JS類本身不支持事件,DOM模型支持的事件僅適應(yīng)于瀏覽器的DOM節(jié)點(diǎn)。所以創(chuàng)建一套事件是我們寫控件之前要做的
概述:
事件對(duì)于控件來說至關(guān)重要,控件的消息通信機(jī)制使用事件的成本最低,但是對(duì)于JS控件來說有一些麻煩需要解決,JS類本身不支持事件,DOM模型支持的事件僅適應(yīng)于瀏覽器的DOM節(jié)點(diǎn)。所以創(chuàng)建一套事件是我們寫控件之前要做的。
事件機(jī)制
對(duì)于事件的機(jī)制我不想多說,各種語言中對(duì)事件的描述都很具體,都是觀察者模式的一種實(shí)現(xiàn),我們可以從中抽取出事件必須的接口(由于控件庫(kù)是基于jQuery 所以接口跟jquery保持一致):
1.on: 綁定事件
2.off: 刪除事件
3.fire: 觸發(fā)事件
4.addTarget : 添加冒泡的對(duì)象
5.publish: 允許事件冒泡
jQuery 中的事件
jQuery 中的事件功能缺失很豐富,但是必須是jQuery對(duì)象才支持,我們自己定義的控件類無法直接使用jQuery的事件,事件的上下文也有問題,所以我們需要自己封裝控件的事件。
jQuery 中的 Callbacks 是 1.7中添加的用于回調(diào)的機(jī)制,使用起來很方便,但是問題也是指定上下文需要在觸發(fā)時(shí)指定,我們可以將其封裝到我們自己的事件類中。
綁定事件:
函數(shù)原型: function on(eventType,callback) 參數(shù):
1.eventType : 事件類型
2.callback : 回調(diào)函數(shù)
3.scope : 回調(diào)函數(shù)的上下文,這個(gè)變量在真正的控件綁定過程中使用的非常少,而且都有替代方案,所以為了簡(jiǎn)單起見,scope變量在此函數(shù)和下面的所有函數(shù)中就引入了。
上面回調(diào)函數(shù)的上下文是綁定事件的控件本身
刪除綁定:
函數(shù)原型 : function off(eventType,callback) 參數(shù)同上:
1.eventType : 事件類型
2.callback : 回調(diào)函數(shù),此變量省略時(shí),刪除這個(gè)事件類型的所有綁定函數(shù)。
在真正的控件開發(fā)和使用過程中,刪除事件比綁定事件要麻煩的多,刪除事件時(shí),你需要有綁定事件時(shí)函數(shù)的引用,如果需要頻繁刪除添加同一個(gè)事件時(shí)請(qǐng)考慮使用delegate
觸發(fā)事件
函數(shù)原型: fire(eventType) :
1. eventType : 事件類型,綁定到對(duì)象上的此類型的函數(shù)執(zhí)行。
這里有2點(diǎn)需要注意:
1.觸發(fā)事件的方式,我們這里使用 ‘stopOnFalse'的方式,也就是綁定在同一個(gè)事件類型下的函數(shù)順序執(zhí)行,如果有一個(gè)返回值為false,那么下面的函數(shù)終止執(zhí)行。其他觸發(fā)事件的方式參考 jquery 的 Callbacks 。
2.事件的是否冒泡執(zhí)行,也就是說,如果一個(gè)控件有多個(gè)子控件,那么子控件觸發(fā)點(diǎn)擊事件時(shí)可以冒泡到父類控件,我們只需要監(jiān)聽父類的冒泡事件即可
事件冒泡
函數(shù)原型: function(eventType,bubble) :
1.eventType : 事件類型
2.bubble : 是否冒泡
此函數(shù)與 function addTarget(control) 相匹配使用。
addTarget 添加事件冒泡到的對(duì)象上,控件實(shí)現(xiàn)中,默認(rèn)指定控件的父控件作為其冒泡的對(duì)象。
上面觸發(fā)事件中講到的,允許控件事件冒泡有很多好處:
1. 事件綁定后,子控件的添加刪除不受影響
2. 事件使用更加方便,不需要去了解控件的內(nèi)部
跟事件冒泡對(duì)應(yīng)的是委托(delegate和 undelegate),委托依賴于事件冒泡,DOM的事件機(jī)制和jQuery都支持委托,這是因?yàn)闉g覽器本身對(duì)DOM 事件冒泡的支持,而我們?cè)诳丶蠈?shí)現(xiàn)的事件冒泡機(jī)制足夠我們實(shí)現(xiàn)委托的效果,所以委托的接口我們就不實(shí)現(xiàn)了。
事件代碼實(shí)現(xiàn)
具體的代碼實(shí)現(xiàn)和一些幫助方法我寫到下面的代碼中,不便于在文章中展開,感興趣的可以看一下,后面的控件庫(kù)都是基于這些幫助方法和事件對(duì)象的。文件里面的其他幫助方法,在其他章節(jié)講解。
事件對(duì)于控件來說至關(guān)重要,控件的消息通信機(jī)制使用事件的成本最低,但是對(duì)于JS控件來說有一些麻煩需要解決,JS類本身不支持事件,DOM模型支持的事件僅適應(yīng)于瀏覽器的DOM節(jié)點(diǎn)。所以創(chuàng)建一套事件是我們寫控件之前要做的。
事件機(jī)制
對(duì)于事件的機(jī)制我不想多說,各種語言中對(duì)事件的描述都很具體,都是觀察者模式的一種實(shí)現(xiàn),我們可以從中抽取出事件必須的接口(由于控件庫(kù)是基于jQuery 所以接口跟jquery保持一致):
1.on: 綁定事件
2.off: 刪除事件
3.fire: 觸發(fā)事件
4.addTarget : 添加冒泡的對(duì)象
5.publish: 允許事件冒泡
jQuery 中的事件
jQuery 中的事件功能缺失很豐富,但是必須是jQuery對(duì)象才支持,我們自己定義的控件類無法直接使用jQuery的事件,事件的上下文也有問題,所以我們需要自己封裝控件的事件。
jQuery 中的 Callbacks 是 1.7中添加的用于回調(diào)的機(jī)制,使用起來很方便,但是問題也是指定上下文需要在觸發(fā)時(shí)指定,我們可以將其封裝到我們自己的事件類中。
綁定事件:
函數(shù)原型: function on(eventType,callback) 參數(shù):
1.eventType : 事件類型
2.callback : 回調(diào)函數(shù)
3.scope : 回調(diào)函數(shù)的上下文,這個(gè)變量在真正的控件綁定過程中使用的非常少,而且都有替代方案,所以為了簡(jiǎn)單起見,scope變量在此函數(shù)和下面的所有函數(shù)中就引入了。
上面回調(diào)函數(shù)的上下文是綁定事件的控件本身
刪除綁定:
函數(shù)原型 : function off(eventType,callback) 參數(shù)同上:
1.eventType : 事件類型
2.callback : 回調(diào)函數(shù),此變量省略時(shí),刪除這個(gè)事件類型的所有綁定函數(shù)。
在真正的控件開發(fā)和使用過程中,刪除事件比綁定事件要麻煩的多,刪除事件時(shí),你需要有綁定事件時(shí)函數(shù)的引用,如果需要頻繁刪除添加同一個(gè)事件時(shí)請(qǐng)考慮使用delegate
觸發(fā)事件
函數(shù)原型: fire(eventType) :
1. eventType : 事件類型,綁定到對(duì)象上的此類型的函數(shù)執(zhí)行。
這里有2點(diǎn)需要注意:
1.觸發(fā)事件的方式,我們這里使用 ‘stopOnFalse'的方式,也就是綁定在同一個(gè)事件類型下的函數(shù)順序執(zhí)行,如果有一個(gè)返回值為false,那么下面的函數(shù)終止執(zhí)行。其他觸發(fā)事件的方式參考 jquery 的 Callbacks 。
2.事件的是否冒泡執(zhí)行,也就是說,如果一個(gè)控件有多個(gè)子控件,那么子控件觸發(fā)點(diǎn)擊事件時(shí)可以冒泡到父類控件,我們只需要監(jiān)聽父類的冒泡事件即可
事件冒泡
函數(shù)原型: function(eventType,bubble) :
1.eventType : 事件類型
2.bubble : 是否冒泡
此函數(shù)與 function addTarget(control) 相匹配使用。
addTarget 添加事件冒泡到的對(duì)象上,控件實(shí)現(xiàn)中,默認(rèn)指定控件的父控件作為其冒泡的對(duì)象。
上面觸發(fā)事件中講到的,允許控件事件冒泡有很多好處:
1. 事件綁定后,子控件的添加刪除不受影響
2. 事件使用更加方便,不需要去了解控件的內(nèi)部
跟事件冒泡對(duì)應(yīng)的是委托(delegate和 undelegate),委托依賴于事件冒泡,DOM的事件機(jī)制和jQuery都支持委托,這是因?yàn)闉g覽器本身對(duì)DOM 事件冒泡的支持,而我們?cè)诳丶蠈?shí)現(xiàn)的事件冒泡機(jī)制足夠我們實(shí)現(xiàn)委托的效果,所以委托的接口我們就不實(shí)現(xiàn)了。
事件代碼實(shí)現(xiàn)
具體的代碼實(shí)現(xiàn)和一些幫助方法我寫到下面的代碼中,不便于在文章中展開,感興趣的可以看一下,后面的控件庫(kù)都是基于這些幫助方法和事件對(duì)象的。文件里面的其他幫助方法,在其他章節(jié)講解。
相關(guān)文章
JS+canvas五子棋人機(jī)對(duì)戰(zhàn)實(shí)現(xiàn)步驟詳解
這篇文章主要介紹了JS+canvas五子棋人機(jī)對(duì)戰(zhàn)實(shí)現(xiàn)步驟詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06JS數(shù)組求和的常用方法實(shí)例小結(jié)
這篇文章主要介紹了JS數(shù)組求和的常用方法,結(jié)合實(shí)例形式總結(jié)分析了javascript常見的遍歷、循環(huán)、歸并等數(shù)組操作相關(guān)技巧,需要的朋友可以參考下2019-01-01一個(gè)對(duì)于js this關(guān)鍵字的問題
一個(gè)對(duì)于js this關(guān)鍵字的問題...2007-01-01js將多維數(shù)組轉(zhuǎn)為一維數(shù)組后去重排序
本文主要介紹了js將多維數(shù)組轉(zhuǎn)為一維數(shù)組后去重排序,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06js之encodeURI、encodeURIComponent、decodeURI、decodeURIComponent
這篇文章主要介紹了js之encodeURI、encodeURIComponent、decodeURI、decodeURIComponent的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04用原生js統(tǒng)計(jì)文本行數(shù)的簡(jiǎn)單示例
這篇文章我們來看看如何利用原生的JavaScript實(shí)現(xiàn)統(tǒng)計(jì)文本的行數(shù),代碼實(shí)現(xiàn)起來很簡(jiǎn)單,有需要的可以參考借鑒。2016-08-08利用JS實(shí)現(xiàn)數(shù)字增長(zhǎng)
做項(xiàng)目時(shí)候常常遇到,要做一個(gè)數(shù)字滾動(dòng)增加的效果。如何利用JavaScript實(shí)現(xiàn)數(shù)字增長(zhǎng)效果,一起來跟本文學(xué)習(xí)學(xué)習(xí)。2016-07-07JS打印gridview實(shí)現(xiàn)原理及代碼
打印gridview對(duì)于一些童鞋們真的是很陌生啊,不過沒有關(guān)系,因?yàn)楸疚牡某霈F(xiàn),或讓你茅塞頓開,好了話不多說,感興趣的朋友可以了解下,或許對(duì)你學(xué)習(xí)js高級(jí)知識(shí)有所幫助2013-02-02