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

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



這么多的組件,可都是非??岬?。組件使用可以直接通過關(guān)鍵字new 來創(chuàng)建,比如上篇文章中說到的創(chuàng)建一個Window框
var win=new Ext.Window();
除了這種創(chuàng)建方式,一般都會在構(gòu)造函數(shù)中加一些配置屬性來初始化組件。比如創(chuàng)建一個面板:
<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>一個面板</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>一個面板</h1>"};
var panel=new Ext.Panel(params);
panel.render("panel");
}
params是設(shè)置Panle的參數(shù),title:標題,width:寬度,height:高度,html:面板顯示的內(nèi)容
var panel=new Ext.Panel(params); 這句代碼創(chuàng)建了一個面板,并在構(gòu)造函數(shù)中設(shè)置了面板屬性。
panel.render("panel"); 表示頁面上的div元素id.、
代碼可以簡寫為:
var panel=new Ext.Panel({renderTo:"panel",title:"Hello",width:300,height:200,html:"<h1>一個面板</h1>"});

對于組件中的子元素組件,都支持延遲加載的方式創(chuàng)建控件,此時可以直接通過父容器的items傳遞數(shù)組方式實現(xiàn)。
function panel(){
var params={
title:"Hello",
width:300,
height:200,
html:"<h1>一個面板</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對框架進行了非常大的重構(gòu),其中最重要的是形成了一個結(jié)構(gòu)及層次分明的組件體系,由這些組件形成了Ext控件。Ext組件由Component類定義,每一種組件都有一個指定的xtype屬性值,通過該值可以得到一個組件的類型或者是定義一個指定類型的組件。
Ext組件體系由下圖所示:

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



這么多的組件,可都是非??岬?。組件使用可以直接通過關(guān)鍵字new 來創(chuàng)建,比如上篇文章中說到的創(chuàng)建一個Window框
var win=new Ext.Window();
除了這種創(chuàng)建方式,一般都會在構(gòu)造函數(shù)中加一些配置屬性來初始化組件。比如創(chuàng)建一個面板:
<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>一個面板</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>一個面板</h1>"};
var panel=new Ext.Panel(params);
panel.render("panel");
}
params是設(shè)置Panle的參數(shù),title:標題,width:寬度,height:高度,html:面板顯示的內(nèi)容
var panel=new Ext.Panel(params); 這句代碼創(chuàng)建了一個面板,并在構(gòu)造函數(shù)中設(shè)置了面板屬性。
panel.render("panel"); 表示頁面上的div元素id.、
代碼可以簡寫為:
復制代碼 代碼如下:
var panel=new Ext.Panel({renderTo:"panel",title:"Hello",width:300,height:200,html:"<h1>一個面板</h1>"});

對于組件中的子元素組件,都支持延遲加載的方式創(chuàng)建控件,此時可以直接通過父容器的items傳遞數(shù)組方式實現(xiàn)。
function panel(){
var params={
title:"Hello",
width:300,
height:200,
html:"<h1>一個面板</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實現(xiàn)通用的微信分享組件示例
- JS表格組件神器bootstrap table詳解(基礎(chǔ)版)
- JS組件Bootstrap實現(xiàn)彈出框和提示框效果代碼
- JS組件Bootstrap Select2使用方法詳解
- JS組件Bootstrap Table使用方法詳解
- Js組件的一些寫法
- 解決Extjs 4 Panel作為Window組件的子組件時出現(xiàn)雙重邊框問題
- jquery滾動組件(vticker.js)實現(xiàn)頁面動態(tài)數(shù)據(jù)的滾動效果
- JS組件Form表單驗證神器BootstrapValidator
- JS組件系列之使用HTML標簽的data屬性初始化JS組件
相關(guān)文章
Extjs Gird 支持中文拼音排序?qū)崿F(xiàn)代碼
本文為大家詳細介紹下Extjs Gird 支持中文拼音排序以及修復漢字排序異常的Bug、localeCompare比較漢字字符串,F(xiàn)irefox與IE均支持,感興趣的朋友可以參考下2013-04-04
ExtJS4 表格的嵌套 rowExpander應(yīng)用
今天做一個grid,里面的數(shù)據(jù)需要帶明細,思來想去還是搞個表格嵌套吧,需要的朋友可以參考下2014-05-05
Ext中下拉列表ComboBox組件store數(shù)據(jù)格式用法介紹
本文為大家詳細介紹下Ext中下拉列表ComboBox組件store數(shù)據(jù)格式的基本用法,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-07-07
EXTjs4.0的store的findRecord的BUG演示代碼
EXTjs4.0 的store的findRecord的BUG:當判斷ID=1的時候,遇到1開頭的ID的時候,這個時候就判斷出問題了,有類似問題的朋友可以了解下哈2013-06-06
解決extjs grid 不隨窗口大小自適應(yīng)的改變問題
在使用grid的時候窗口改變了但是grid卻不能自適應(yīng),下面有個不粗的解決方法,大家可以參考下2014-01-01
Ext JS框架中日期函數(shù)的用法及日期選擇控件的實現(xiàn)
Ext JS中的Ext.Date可以看作是JavaScript中date的加強版,提供了許多進階的日期操作函數(shù),下面我們就來看一下Ext JS框架中日期函數(shù)的用法及日期選擇控件的實現(xiàn)2016-05-05
Ext JS 4實現(xiàn)帶week(星期)的日期選擇控件(實戰(zhàn)一)
有一些日期選擇的需求是要看到星期,就是日期中的哪一天是這一年的第幾周,遺憾的是Ext js 并沒有提供這樣的配置,下面為大家分享下理想的解決方法2013-08-08

