ExtJs 學(xué)習(xí)筆記基礎(chǔ)篇 Ext組件的使用第1/2頁
更新時(shí)間:2008年12月29日 23:07:18 作者:
昨天剛接觸到Extjs,簡單寫了篇學(xué)習(xí)筆記,今天繼續(xù)。
天介紹一下Ext中組件舉幾個(gè)簡單的例子做說明。注意:文章內(nèi)容有些摘自本人學(xué)習(xí)過程中看到的資料。
Ext2.0對(duì)框架進(jìn)行了非常大的重構(gòu),其中最重要的是形成了一個(gè)結(jié)構(gòu)及層次分明的組件體系,由這些組件形成了Ext控件。Ext組件由Component類定義,每一種組件都有一個(gè)指定的xtype屬性值,通過該值可以得到一個(gè)組件的類型或者是定義一個(gè)指定類型的組件。
Ext組件體系由下圖所示:

組件大致可分成三大類,即基本組件、工具欄組件、表單元素組件。
基本組件有



這么多的組件,可都是非??岬?。組件使用可以直接通過關(guān)鍵字new 來創(chuàng)建,比如上篇文章中說到的創(chuàng)建一個(gè)Window框
var win=new Ext.Window();
除了這種創(chuàng)建方式,一般都會(huì)在構(gòu)造函數(shù)中加一些配置屬性來初始化組件。比如創(chuàng)建一個(gè)面板:
<html>
<head>
<link rel="stylesheet" type="text/css" href="extjs/resources/css/ext-all.css" />
<script src="extjs/ext-base.js" type="text/javascript"></script>
<script src="extjs/ext-all.js" type="text/javascript"></script>
<script src="extjs/ext-lang-zh_CN.js" type="text/javascript"></script>
<script language="javascript">
function panel(){
var params={title:"Hello",width:300,height:200,html:"<h1>一個(gè)面板</h1>"};
var panel=new Ext.Panel(params);
panel.render("panel");
}
</script>
</head>
<body>
<input type="button" onclick="panel()" value="顯示面板">
<hr/>
<div id="panel"></div>
</body>
</html>
關(guān)鍵代碼:
function panel(){
var params={title:"Hello",width:300,height:200,html:"<h1>一個(gè)面板</h1>"};
var panel=new Ext.Panel(params);
panel.render("panel");
}
params是設(shè)置Panle的參數(shù),title:標(biāo)題,width:寬度,height:高度,html:面板顯示的內(nèi)容
var panel=new Ext.Panel(params); 這句代碼創(chuàng)建了一個(gè)面板,并在構(gòu)造函數(shù)中設(shè)置了面板屬性。
panel.render("panel"); 表示頁面上的div元素id.、
代碼可以簡寫為:
var panel=new Ext.Panel({renderTo:"panel",title:"Hello",width:300,height:200,html:"<h1>一個(gè)面板</h1>"});

對(duì)于組件中的子元素組件,都支持延遲加載的方式創(chuàng)建控件,此時(shí)可以直接通過父容器的items傳遞數(shù)組方式實(shí)現(xiàn)。
function panel(){
var params={
title:"Hello",
width:300,
height:200,
html:"<h1>一個(gè)面板</h1>",
items:[
new Ext.Panel({title:"Panel1",height:100}),
new Ext.Panel({title:"Panel2",height:100})
]
};
var panel=new Ext.Panel(params);
panel.render("panel");
}

如果需要讓組件顯示出不同的效果,我們就需要通過構(gòu)造函數(shù)中的參數(shù)設(shè)置。
由于組件都繼承自Ext.Component,因此所有組件可能有共同的屬性,如下圖

Ext2.0對(duì)框架進(jìn)行了非常大的重構(gòu),其中最重要的是形成了一個(gè)結(jié)構(gòu)及層次分明的組件體系,由這些組件形成了Ext控件。Ext組件由Component類定義,每一種組件都有一個(gè)指定的xtype屬性值,通過該值可以得到一個(gè)組件的類型或者是定義一個(gè)指定類型的組件。
Ext組件體系由下圖所示:

組件大致可分成三大類,即基本組件、工具欄組件、表單元素組件。
基本組件有



這么多的組件,可都是非??岬?。組件使用可以直接通過關(guān)鍵字new 來創(chuàng)建,比如上篇文章中說到的創(chuàng)建一個(gè)Window框
var win=new Ext.Window();
除了這種創(chuàng)建方式,一般都會(huì)在構(gòu)造函數(shù)中加一些配置屬性來初始化組件。比如創(chuàng)建一個(gè)面板:
<html>
<head>
<link rel="stylesheet" type="text/css" href="extjs/resources/css/ext-all.css" />
<script src="extjs/ext-base.js" type="text/javascript"></script>
<script src="extjs/ext-all.js" type="text/javascript"></script>
<script src="extjs/ext-lang-zh_CN.js" type="text/javascript"></script>
<script language="javascript">
function panel(){
var params={title:"Hello",width:300,height:200,html:"<h1>一個(gè)面板</h1>"};
var panel=new Ext.Panel(params);
panel.render("panel");
}
</script>
</head>
<body>
<input type="button" onclick="panel()" value="顯示面板">
<hr/>
<div id="panel"></div>
</body>
</html>
關(guān)鍵代碼:
function panel(){
var params={title:"Hello",width:300,height:200,html:"<h1>一個(gè)面板</h1>"};
var panel=new Ext.Panel(params);
panel.render("panel");
}
params是設(shè)置Panle的參數(shù),title:標(biāo)題,width:寬度,height:高度,html:面板顯示的內(nèi)容
var panel=new Ext.Panel(params); 這句代碼創(chuàng)建了一個(gè)面板,并在構(gòu)造函數(shù)中設(shè)置了面板屬性。
panel.render("panel"); 表示頁面上的div元素id.、
代碼可以簡寫為:
復(fù)制代碼 代碼如下:
var panel=new Ext.Panel({renderTo:"panel",title:"Hello",width:300,height:200,html:"<h1>一個(gè)面板</h1>"});

對(duì)于組件中的子元素組件,都支持延遲加載的方式創(chuàng)建控件,此時(shí)可以直接通過父容器的items傳遞數(shù)組方式實(shí)現(xiàn)。
function panel(){
var params={
title:"Hello",
width:300,
height:200,
html:"<h1>一個(gè)面板</h1>",
items:[
new Ext.Panel({title:"Panel1",height:100}),
new Ext.Panel({title:"Panel2",height:100})
]
};
var panel=new Ext.Panel(params);
panel.render("panel");
}

如果需要讓組件顯示出不同的效果,我們就需要通過構(gòu)造函數(shù)中的參數(shù)設(shè)置。
由于組件都繼承自Ext.Component,因此所有組件可能有共同的屬性,如下圖


您可能感興趣的文章:
- 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