ExtJs 學(xué)習(xí)筆記基礎(chǔ)篇 Ext組件的使用第2/2頁(yè)
Extjs提供了一套強(qiáng)大的事件處理機(jī)制,專(zhuān)門(mén)處理用戶動(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ì)象。支持事件處理的類(lèi)(或?yàn)榻涌冢镋xt.util.Observable,凡事繼承該類(lèi)的組件或類(lèi)都支持往對(duì)象中添加時(shí)間處理及響應(yīng)功能。
我們?cè)陧?yè)面上加一個(gè)按鈕
<input type="button" id="btntest" value="測(cè)試事件">
在寫(xiě)一個(gè)函數(shù)
function eventtest(){
Ext.Msg.alert("提示","觸發(fā)了一個(gè)事件!");
}
下面通過(guò)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í)行方法,無(wú)需加括弧);
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ì)在銷(xiāo)毀這一組件時(shí)觸發(fā)該事件。 這段代碼會(huì)顯示一個(gè)窗體,并且點(diǎn)擊關(guān)閉按鈕時(shí)會(huì)失效。通過(guò)Window的on方法來(lái)控制.. on(事件,事件執(zhí)行函數(shù)).由于窗口對(duì)象的beforedestroy事件響應(yīng)函數(shù)返回值為false,因此執(zhí)行這段程序,窗體才無(wú)法關(guān)閉。組件的時(shí)間監(jiān)聽(tīng)器也可以直接在構(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組件的介紹與使用。各位有什么問(wèn)題可以留言一起討論,有什么不對(duì)的地方請(qǐng)指正。
此文章中用的例子都只是簡(jiǎn)單介紹,后面會(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組件的一些寫(xiě)法
- 解決Extjs 4 Panel作為Window組件的子組件時(shí)出現(xiàn)雙重邊框問(wèn)題
- jquery滾動(dòng)組件(vticker.js)實(shí)現(xiàn)頁(yè)面動(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í)間格式中,往往都是 類(lèi)似 "\/Date(1309200300000)\/"的日期時(shí)間格式,結(jié)果導(dǎo)致無(wú)法正常在TimeField中顯示2011-06-06Ext JS Grid在IE6 下寬度的問(wèn)題解決方法
Grid設(shè)置為autoWidth:true時(shí)在ie6下寬度為10000px2009-02-02Extjs讓combobox寫(xiě)起來(lái)簡(jiǎn)潔又漂亮
代碼看起來(lái)簡(jiǎn)潔又漂亮是如何做到的,這篇文章主要為大家詳細(xì)介紹了Extjs如何讓combobox寫(xiě)起來(lái)更簡(jiǎn)單,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01ext combobox動(dòng)態(tài)加載數(shù)據(jù)庫(kù)數(shù)據(jù)(附前后臺(tái))
這篇文章主要介紹了ext combobox動(dòng)態(tài)加載數(shù)據(jù)庫(kù)數(shù)據(jù)并附前后臺(tái)實(shí)現(xiàn),需要的朋友可以參考下2014-06-06ExtJS 2.0 實(shí)用簡(jiǎn)明教程之布局概述
所謂布局就是指容器組件中子元素的分布、排列組合方式。Ext的所有容器組件都支持而局操作,每一個(gè)容器都會(huì)有一個(gè)對(duì)應(yīng)的布局,布局負(fù)責(zé)管理容器組件中子元素的排列、組合及渲染方式等。2009-04-04關(guān)于extjs4如何獲取grid修改后的數(shù)據(jù)的問(wèn)題
如何獲取grid修改后的數(shù)據(jù)問(wèn)題,下面是API的描述??梢垣@取各種值,感興趣的朋友可以參考下2013-08-08Extjs實(shí)現(xiàn)進(jìn)度條的兩種便捷方式
后臺(tái)程序往往可能要執(zhí)行一段時(shí)間才能得到返回結(jié)果,加入進(jìn)度條可以提高客戶體驗(yàn)度,在本文為大家介紹兩種便捷的實(shí)現(xiàn)方式,感興趣的朋友可以了解下2013-09-09JavaScript的ExtJS框架中表格的編寫(xiě)教程
ExtJS是一個(gè)MVVM結(jié)構(gòu)的JavaScript框架,在處理表格表單方面則是它的拿手好戲,這里整理了基本的JavaScript的ExtJS框架中表格的編寫(xiě)教程2016-05-05