ExtJs 學(xué)習(xí)筆記基礎(chǔ)篇 Ext組件的使用
更新時(shí)間:2008年12月29日 23:07:18 作者:
昨天剛接觸到Extjs,簡單寫了篇學(xué)習(xí)筆記,今天繼續(xù)。
Extjs提供了一套強(qiáng)大的事件處理機(jī)制,專門處理用戶動(dòng)作、監(jiān)控控件狀態(tài)、更新控件視圖信息、與服務(wù)器交互等等。事件由Ext.EventManager對(duì)象管理,與瀏覽器W3C標(biāo)準(zhǔn)事件對(duì)象Event相對(duì)應(yīng),Ext封裝了一個(gè)Ext.EventObject事件對(duì)象。支持事件處理的類(或?yàn)榻涌冢镋xt.util.Observable,凡事繼承該類的組件或類都支持往對(duì)象中添加時(shí)間處理及響應(yīng)功能。
我們?cè)陧撁嫔霞右粋€(gè)按鈕
<input type="button" id="btntest" value="測試事件">
在寫一個(gè)函數(shù)
function eventtest(){
Ext.Msg.alert("提示","觸發(fā)了一個(gè)事件!");
}
下面通過Ext的事件處理機(jī)制為btntest這個(gè)按鈕添加一個(gè)點(diǎn)擊事件,點(diǎn)擊后調(diào)用eventtest方法。
Ext.onReady(
function(){
Ext.get("btntest").addListener("click",eventtest);
}
);
在Ext組件加載完畢后直接給按鈕添加一個(gè)click事件。Ext.get("btntest").addListener(事件,事件執(zhí)行方法,無需加括弧);
Ext還支持延遲事件處理緩存等功能,比如下面的代碼:
Ext.get("btntest1").addListener("click",eventtest,this,{delay:2000});
<input type="button" id="btntest1" value="延遲事件">
Ext.get("btntest1").addListener("click",eventtest,this,{delay:2000});這句代碼為按鈕注冊(cè)了一個(gè)click事件,但會(huì)延遲2000毫秒執(zhí)行。
可以為html元素添加事件了,我們還可以控制Ext組件的事件,在看一個(gè)例子。
function eventwindow(){
var win=new Ext.Window({
title:"控制Ext組件的事件",
height:200,
width:300
});
win.on(
"beforedestroy",
function(obj){
Ext.Msg.alert("哈哈","你關(guān)不掉了吧!");
obj.show();
return false;
}
);
win.show();
}
每個(gè)組件都含有beforedestroy事件,Ext會(huì)在銷毀這一組件時(shí)觸發(fā)該事件。 這段代碼會(huì)顯示一個(gè)窗體,并且點(diǎn)擊關(guān)閉按鈕時(shí)會(huì)失效。通過Window的on方法來控制.. on(事件,事件執(zhí)行函數(shù)).由于窗口對(duì)象的beforedestroy事件響應(yīng)函數(shù)返回值為false,因此執(zhí)行這段程序,窗體才無法關(guān)閉。組件的時(shí)間監(jiān)聽器也可以直接在構(gòu)造函數(shù)中直接聲明,下面的代碼會(huì)和上面同一效果:
function eventwindow(){
var win=new Ext.Window({
title:"控制Ext組件的事件",
height:200,
width:300,
listeners:{
"beforedestroy":
function(obj){
Ext.Msg.alert("哈哈","你關(guān)不掉了吧!");
obj.show();
return false;
}
}
});
win.show();
}
效果如下:

OK,這就是Ext組件的介紹與使用。各位有什么問題可以留言一起討論,有什么不對(duì)的地方請(qǐng)指正。
此文章中用的例子都只是簡單介紹,后面會(huì)詳細(xì)講解。
文章中案例代碼下載 http://xiazai.jb51.net/200812/yuanma/jb51.net_ExtJsDemo2.rar
您可能感興趣的文章:
- js實(shí)現(xiàn)通用的微信分享組件示例
- JS表格組件神器bootstrap table詳解(基礎(chǔ)版)
- JS組件Bootstrap實(shí)現(xiàn)彈出框和提示框效果代碼
- JS組件Bootstrap Select2使用方法詳解
- JS組件Bootstrap Table使用方法詳解
- Js組件的一些寫法
- 解決Extjs 4 Panel作為Window組件的子組件時(shí)出現(xiàn)雙重邊框問題
- jquery滾動(dòng)組件(vticker.js)實(shí)現(xiàn)頁面動(dòng)態(tài)數(shù)據(jù)的滾動(dòng)效果
- JS組件Form表單驗(yàn)證神器BootstrapValidator
- JS組件系列之使用HTML標(biāo)簽的data屬性初始化JS組件
相關(guān)文章
Extjs TimeField 顯示正常時(shí)間格式的代碼
由后臺(tái)返回的json的日期時(shí)間格式中,往往都是 類似 "\/Date(1309200300000)\/"的日期時(shí)間格式,結(jié)果導(dǎo)致無法正常在TimeField中顯示2011-06-06ext combobox動(dòng)態(tài)加載數(shù)據(jù)庫數(shù)據(jù)(附前后臺(tái))
這篇文章主要介紹了ext combobox動(dòng)態(tài)加載數(shù)據(jù)庫數(shù)據(jù)并附前后臺(tái)實(shí)現(xiàn),需要的朋友可以參考下2014-06-06關(guān)于extjs4如何獲取grid修改后的數(shù)據(jù)的問題
如何獲取grid修改后的數(shù)據(jù)問題,下面是API的描述??梢垣@取各種值,感興趣的朋友可以參考下2013-08-08Extjs實(shí)現(xiàn)進(jìn)度條的兩種便捷方式
后臺(tái)程序往往可能要執(zhí)行一段時(shí)間才能得到返回結(jié)果,加入進(jìn)度條可以提高客戶體驗(yàn)度,在本文為大家介紹兩種便捷的實(shí)現(xiàn)方式,感興趣的朋友可以了解下2013-09-09