extjs 為某個事件設(shè)置攔截器
更新時間:2010年01月15日 16:32:04 作者:
Ext.util.Observable有一個重要的功能,可以為某個事件設(shè)置攔截器,統(tǒng)一管理方法的處罰。使用capture()和releaseCapture()來實現(xiàn)這個功能。
我們先來自定義一個事件:
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 + '在走啊走啊。');
});
然后我們再定義一個按鈕用來觸發(fā)這個walk事件:
var btn = new Ext.Button({
id: 'walk',
text: '觸發(fā)事件按鈕',
renderTo: Ext.getBody()
});
btn.on('click', function() {
person.fireEvent('walk');
});
當(dāng)點擊按鈕時觸發(fā)事件,效果如下圖所示:

現(xiàn)在我們使用capture()函數(shù)攔截事件的觸發(fā),如下面的代碼所示:
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ā)現(xiàn)彈出對話框后還會觸發(fā)事件,郁悶。。。?,F(xiàn)在將最后一行代碼改為return false試試?事件被攔截成功了吧!
這樣就給我們一個選擇的機(jī)會,通過控制capture()中處理函數(shù)的返回值來決定是否繼續(xù)執(zhí)行某個時間的監(jiān)聽函數(shù),還是直接中止該事件的發(fā)生。
我們還可以為一個對象設(shè)置多個capture()攔截函數(shù),這些攔截函數(shù)會形成一個處理鏈條,只要其中任何一個攔截函數(shù)返回false,就會中止處理過程。
releaseCapture()函數(shù)是capture()函數(shù)的反向操作,它會一次性清除fireEvent()上所有的攔截函數(shù),不過我們無法通過它準(zhǔn)確的刪除某一個攔截函數(shù)。一旦執(zhí)行了releaseCapture(),那么之前設(shè)置的所有攔截函數(shù)就都失效了。
復(fù)制代碼 代碼如下:
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 + '在走啊走啊。');
});
然后我們再定義一個按鈕用來觸發(fā)這個walk事件:
復(fù)制代碼 代碼如下:
var btn = new Ext.Button({
id: 'walk',
text: '觸發(fā)事件按鈕',
renderTo: Ext.getBody()
});
btn.on('click', function() {
person.fireEvent('walk');
});
當(dāng)點擊按鈕時觸發(fā)事件,效果如下圖所示:

現(xiàn)在我們使用capture()函數(shù)攔截事件的觸發(fā),如下面的代碼所示:
復(fù)制代碼 代碼如下:
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ā)現(xiàn)彈出對話框后還會觸發(fā)事件,郁悶。。。?,F(xiàn)在將最后一行代碼改為return false試試?事件被攔截成功了吧!
這樣就給我們一個選擇的機(jī)會,通過控制capture()中處理函數(shù)的返回值來決定是否繼續(xù)執(zhí)行某個時間的監(jiān)聽函數(shù),還是直接中止該事件的發(fā)生。
我們還可以為一個對象設(shè)置多個capture()攔截函數(shù),這些攔截函數(shù)會形成一個處理鏈條,只要其中任何一個攔截函數(shù)返回false,就會中止處理過程。
releaseCapture()函數(shù)是capture()函數(shù)的反向操作,它會一次性清除fireEvent()上所有的攔截函數(shù),不過我們無法通過它準(zhǔn)確的刪除某一個攔截函數(shù)。一旦執(zhí)行了releaseCapture(),那么之前設(shè)置的所有攔截函數(shù)就都失效了。
相關(guān)文章
extjs中g(shù)rid中嵌入動態(tài)combobox的應(yīng)用
今天需要在grid中嵌入combobox,在網(wǎng)上找了好久也沒有找到一個正確可行的方法,可能是版本問題(我版本是extjs 3.0),沒有繼續(xù)研究其原因,自己查找資料,終于實現(xiàn)功能?,F(xiàn)在分享一下代碼。2011-01-01
學(xué)習(xí)ExtJS TextField常用方法
ExtJS TextField常用方法2009-10-10
Extjs4 Treegrid 使用心得分享(經(jīng)驗篇)
最近調(diào)試EXTJS 4的treegrid實例,看了很多水友的文章,以及官方的demo,沒一個可靠的,于是乎自己折騰中...感興趣的朋友可以了解下本文或許對你有所幫助2013-07-07
入門基礎(chǔ)學(xué)習(xí) ExtJS筆記(一)
這段時間手中項目已經(jīng)完成,空閑時間較多。開始了學(xué)習(xí)ExtJs之旅。2010-11-11
解決ExtJS在chrome或火狐中正常顯示在ie中不顯示的瀏覽器兼容問題
由于開發(fā)過程中大多用chrome來調(diào)試,很少在ie中調(diào)試(現(xiàn)在兩者都要兼顧),導(dǎo)致最后在ie中頁面不能正常加載,當(dāng)時那個囧啊,看到ie報的錯,我都想哭,連出錯的堆棧信息都沒有(這一點,ie做的真不好),無從下手啊2013-01-01

