一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

extjs 為某個事件設置攔截器

我們先來自定義一個事件:
復制代碼 代碼如下:
person = function(name) {
this.name = name;
this.addEvents("walk");
}
Ext.extend(person, Ext.util.Observable, {
info: function(event) {
return this.name + 'is' + event + 'ing.';
}
});
var person = new person('張銘諾');
person.on('walk', function() {
Ext.Msg.alert('event', person.name + '在走啊走啊。');
});

然后我們再定義一個按鈕用來觸發這個walk事件:
復制代碼 代碼如下:
var btn = new Ext.Button({
id: 'walk',
text: '觸發事件按鈕',
renderTo: Ext.getBody()
});
btn.on('click', function() {
person.fireEvent('walk');
});

當點擊按鈕時觸發事件,效果如下圖所示:

現在我們使用capture()函數攔截事件的觸發,如下面的代碼所示:
復制代碼 代碼如下:
var btn2 = new Ext.Button({
id: 'cc',
text: '攔截事件',
renderTo: Ext.getBody()
});
btn2.on('click', function() {
Ext.util.Observable.capture(person, function() {
alert('fsdjhf');
return true;
});
});


這時單擊btn2按鈕,發現彈出對話框后還會觸發事件,郁悶。。?!,F在將最后一行代碼改為return false試試?事件被攔截成功了吧!

  這樣就給我們一個選擇的機會,通過控制capture()中處理函數的返回值來決定是否繼續執行某個時間的監聽函數,還是直接中止該事件的發生。

我們還可以為一個對象設置多個capture()攔截函數,這些攔截函數會形成一個處理鏈條,只要其中任何一個攔截函數返回false,就會中止處理過程。

releaseCapture()函數是capture()函數的反向操作,它會一次性清除fireEvent()上所有的攔截函數,不過我們無法通過它準確的刪除某一個攔截函數。一旦執行了releaseCapture(),那么之前設置的所有攔截函數就都失效了。

JavaScript技術extjs 為某個事件設置攔截器,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 日本aⅴ永久免费网站www | 91久久青青青国产免费 | 国产视频第一页 | 91精品国产免费久久久久久青草 | 国产精品女人在线观看 | 久久久久久久久影院 | 大学生一级毛片全黄真人 | 亚洲天堂毛片 | 怡红院亚洲红怡院天堂麻豆 | 婷婷六月丁香午夜爱爱 | 亚洲伊人精品综合在合线 | 亚洲一区www | 亚洲精品在线影院 | 高清一区二区在线观看 | 国产99久久精品 | 日韩一区二区三区免费视频 | 综合伊人久久在一二三区 | 最新亚洲一区二区三区四区 | 久久香蕉国产精品一区二区三 | 色综合图| 好好的日视频www | 亚洲专区视频 | 亚洲黄色激情网 | 最近中文字幕完先锋资源 | 国产精品亚洲专一区二区三区 | 免费在线观看黄色小视频 | 婷婷五月在线视频 | 久久精品国产自在一线 | 福利一区二区在线 | 日韩a无v码在线播放免费 | 97精品久久久久中文字幕 | 国产精品第一区在线观看 | 国产精品视频自拍 | 美女一级毛片毛片在线播放 | 国产永久在线视频 | 欧美黑人猛xxxxbbbb | 凹凸精品视频分类国产品免费 | 久久国产乱子伦精品在 | 91视频专区 | 夜夜五月天 | 国产一级特黄的片子 |