亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JS 控件事件小結

 更新時間:2012年10月31日 14:57:23   作者:  
事件對于控件來說至關重要,控件的消息通信機制使用事件的成本最低,但是對于JS控件來說有一些麻煩需要解決,JS類本身不支持事件,DOM模型支持的事件僅適應于瀏覽器的DOM節(jié)點。所以創(chuàng)建一套事件是我們寫控件之前要做的
概述:

事件對于控件來說至關重要,控件的消息通信機制使用事件的成本最低,但是對于JS控件來說有一些麻煩需要解決,JS類本身不支持事件,DOM模型支持的事件僅適應于瀏覽器的DOM節(jié)點。所以創(chuàng)建一套事件是我們寫控件之前要做的。

事件機制

對于事件的機制我不想多說,各種語言中對事件的描述都很具體,都是觀察者模式的一種實現,我們可以從中抽取出事件必須的接口(由于控件庫是基于jQuery 所以接口跟jquery保持一致):

1.on: 綁定事件

2.off: 刪除事件

3.fire: 觸發(fā)事件

4.addTarget : 添加冒泡的對象

5.publish: 允許事件冒泡

jQuery 中的事件

jQuery 中的事件功能缺失很豐富,但是必須是jQuery對象才支持,我們自己定義的控件類無法直接使用jQuery的事件,事件的上下文也有問題,所以我們需要自己封裝控件的事件。

jQuery 中的 Callbacks 是 1.7中添加的用于回調的機制,使用起來很方便,但是問題也是指定上下文需要在觸發(fā)時指定,我們可以將其封裝到我們自己的事件類中。

綁定事件:

函數原型: function on(eventType,callback) 參數:
1.eventType : 事件類型
2.callback : 回調函數
3.scope : 回調函數的上下文,這個變量在真正的控件綁定過程中使用的非常少,而且都有替代方案,所以為了簡單起見,scope變量在此函數和下面的所有函數中就引入了。

上面回調函數的上下文是綁定事件的控件本身

刪除綁定:
函數原型 : function off(eventType,callback) 參數同上:

1.eventType : 事件類型
2.callback : 回調函數,此變量省略時,刪除這個事件類型的所有綁定函數。
在真正的控件開發(fā)和使用過程中,刪除事件比綁定事件要麻煩的多,刪除事件時,你需要有綁定事件時函數的引用,如果需要頻繁刪除添加同一個事件時請考慮使用delegate

觸發(fā)事件
函數原型: fire(eventType) :

1. eventType : 事件類型,綁定到對象上的此類型的函數執(zhí)行。

這里有2點需要注意:

1.觸發(fā)事件的方式,我們這里使用 ‘stopOnFalse'的方式,也就是綁定在同一個事件類型下的函數順序執(zhí)行,如果有一個返回值為false,那么下面的函數終止執(zhí)行。其他觸發(fā)事件的方式參考 jquery 的 Callbacks 。

2.事件的是否冒泡執(zhí)行,也就是說,如果一個控件有多個子控件,那么子控件觸發(fā)點擊事件時可以冒泡到父類控件,我們只需要監(jiān)聽父類的冒泡事件即可

事件冒泡

函數原型: function(eventType,bubble) :

1.eventType : 事件類型
2.bubble : 是否冒泡

此函數與 function addTarget(control) 相匹配使用。

addTarget 添加事件冒泡到的對象上,控件實現中,默認指定控件的父控件作為其冒泡的對象。

上面觸發(fā)事件中講到的,允許控件事件冒泡有很多好處:

1. 事件綁定后,子控件的添加刪除不受影響

2. 事件使用更加方便,不需要去了解控件的內部

跟事件冒泡對應的是委托(delegate和 undelegate),委托依賴于事件冒泡,DOM的事件機制和jQuery都支持委托,這是因為瀏覽器本身對DOM 事件冒泡的支持,而我們在控件上實現的事件冒泡機制足夠我們實現委托的效果,所以委托的接口我們就不實現了。


事件代碼實現

具體的代碼實現和一些幫助方法我寫到下面的代碼中,不便于在文章中展開,感興趣的可以看一下,后面的控件庫都是基于這些幫助方法和事件對象的。文件里面的其他幫助方法,在其他章節(jié)講解。

相關文章

  • JS+canvas五子棋人機對戰(zhàn)實現步驟詳解

    JS+canvas五子棋人機對戰(zhàn)實現步驟詳解

    這篇文章主要介紹了JS+canvas五子棋人機對戰(zhàn)實現步驟詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-06-06
  • JS數組求和的常用方法實例小結

    JS數組求和的常用方法實例小結

    這篇文章主要介紹了JS數組求和的常用方法,結合實例形式總結分析了javascript常見的遍歷、循環(huán)、歸并等數組操作相關技巧,需要的朋友可以參考下
    2019-01-01
  • JS異步加載的三種實現方式

    JS異步加載的三種實現方式

    本篇文章主要介紹了JS異步加載的三種實現方式,有些時候我們需要JS異步加載,這里整理了詳細的代碼,有需要的小伙伴可以參考下。
    2017-03-03
  • 一個對于js this關鍵字的問題

    一個對于js this關鍵字的問題

    一個對于js this關鍵字的問題...
    2007-01-01
  • JS匿名函數實例分析

    JS匿名函數實例分析

    這篇文章主要介紹了JS匿名函數,結合實例形式分析了javascript匿名函數的定義、參數、返回值等相關使用方法,需要的朋友可以參考下
    2016-11-11
  • js將多維數組轉為一維數組后去重排序

    js將多維數組轉為一維數組后去重排序

    本文主要介紹了js將多維數組轉為一維數組后去重排序,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06
  • js之encodeURI、encodeURIComponent、decodeURI、decodeURIComponent

    js之encodeURI、encodeURIComponent、decodeURI、decodeURIComponent

    這篇文章主要介紹了js之encodeURI、encodeURIComponent、decodeURI、decodeURIComponent的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • 用原生js統(tǒng)計文本行數的簡單示例

    用原生js統(tǒng)計文本行數的簡單示例

    這篇文章我們來看看如何利用原生的JavaScript實現統(tǒng)計文本的行數,代碼實現起來很簡單,有需要的可以參考借鑒。
    2016-08-08
  • 利用JS實現數字增長

    利用JS實現數字增長

    做項目時候常常遇到,要做一個數字滾動增加的效果。如何利用JavaScript實現數字增長效果,一起來跟本文學習學習。
    2016-07-07
  • JS打印gridview實現原理及代碼

    JS打印gridview實現原理及代碼

    打印gridview對于一些童鞋們真的是很陌生啊,不過沒有關系,因為本文的出現,或讓你茅塞頓開,好了話不多說,感興趣的朋友可以了解下,或許對你學習js高級知識有所幫助
    2013-02-02

最新評論