ExtJS 配置和表格控件使用
3.6 表格分頁(yè)
Grid控件對(duì)性能要求較高,如果在一個(gè)Grid里面顯示上千條記錄,效率會(huì)有明顯下降,所以必須考慮分頁(yè)問題。
1、為Grid添加分頁(yè)工具條:在前面代碼的基礎(chǔ)上修改grid代碼:
var grid1=new Ext.grid.GridPanel({
renderTo:"grid1",
stripeRows:true,//斑馬線效果
loadMask:true,
store: store1,
height:200,
cm:cm,
viewConfig:{
forceFit:true
},
bbar:new Ext.PagingToolbar({
pageSize:10,
store: store1,
displayInfo:true,
displayMsg:'顯示第{0}條到{1}條記錄,一共{2}條',
emptyMsg:"沒有記錄"
})
});
2、效果圖如圖6所示:

圖6 添加分頁(yè)工具條
3、如果要真正實(shí)現(xiàn)分頁(yè),還需要通過后臺(tái)腳本獲得分頁(yè)數(shù)據(jù),這部分在此不再給出
四、可編輯表格控件——EditorGrid
EditorGrid可以直接在表格里面執(zhí)行添加、刪除、修改、查找等功能,然后一次性保持。還有可以動(dòng)態(tài)修改某個(gè)單元格,這些單元格我們先暫時(shí)不能為空,保存時(shí)會(huì)進(jìn)行檢測(cè),為空就無(wú)法保存,驗(yàn)證信息會(huì)給予提示。
4.1 制作一個(gè)簡(jiǎn)單的EditorGrid
1、定義列,代碼如下:
var cm=new Ext.grid.ColumnModel([
{header:'編號(hào)',dataIndex:'id',width:40,editor:new Ext.grid.GridEditor(
new Ext.form.TextField({
allowBlank:false
})
)},
{header:'名稱',dataIndex:'name',width:180,editor:new Ext.grid.GridEditor(
new Ext.form.TextField({
allowBlank:false
})
)},
{id:'desn',header:'描述',dataIndex:'desn',width:200},
{header:'時(shí)間',dataIndex:'date',type:'date',renderer:Ext.util.Format.dateRenderer('Y年m月d日')}
]);
2、定義grid,注意此時(shí)是EditorGridPanel.
var grid1=new Ext.grid.EditorGridPanel({
renderTo:"grid1",
store: store1,
height:200,
clicksToEdit:1,
cm:cm
});
3、默認(rèn)情況下,需要雙擊單元格才能激活編輯器,從而進(jìn)行修改,不過,也可以給Grid配置clickToEdit:1,這樣就可以單擊單元格激活編輯器,從而進(jìn)行修改,如圖7所示:

圖7 通過單擊修改單元格
五、屬性表格——PropertyGrid
屬性表格擴(kuò)展自EditorGridPanel,所以可以直接編輯右邊的內(nèi)容,注意:只有右邊的,即使你單擊左邊的單元格,編輯器也會(huì)出現(xiàn)在右邊。
定義的方法如下:
<script type="text/javascript"><!--
Ext.onReady(function(){
var grid=new Ext.grid.PropertyGrid({
title:"屬性表格",
autoHeight:true,
width:400,
renderTo:'grid1',
source:{
"名字":"薛敬明",
"創(chuàng)建時(shí)間":new Date(Date.parse('12/15/2009')),
"是否有效":false,
"版本號(hào)":.01,
"描述":"估計(jì)沒有啥說(shuō)的"
}
});
});
// --></script>
效果圖如圖8所示:

六、分組表格——Group
分組表格就是在普通表格的基礎(chǔ)上,根據(jù)某一列的數(shù)據(jù)將表格中的數(shù)據(jù)分組顯示的表格控件。
1、首先定義一組數(shù)據(jù)
var data=[
['1','male','name1','desn1'],
['2','male','name2','desn1'],
['3','female','name3','desn1'],
['4','male','name4','desn1'],
['5','female','name5','desn1'],
['6','male','name6','desn1'],
['7','male','name7','desn1']
];
2、創(chuàng)建表格的列信息
var sm=new Ext.grid.CheckboxSelectionModel();
var cm=new Ext.grid.ColumnModel([
new Ext.grid.RowNumberer(),
sm,
{header:'編號(hào)',dataIndex:'id',width:40,sortable:true},
{header:'性別',dataIndex:'sex',width:180},
{header:'名稱',dataIndex:'name',width:200},
{header:'描述',dataIndex:'desn',width:200}
]);
3、創(chuàng)建數(shù)據(jù)存儲(chǔ)對(duì)象
var store1= new Ext.data.GroupingStore({
proxy:new Ext.data.MemoryProxy(data),
reader:new Ext.data.ArrayReader({},[
{name:'id'},
{name:'sex'},
{name:'name'},
{name:'desn'}
]),
groupField:'sex',
sortInfo:{field:'id',direction:"ASC"}
});
store1.load();
4、設(shè)計(jì)分組設(shè)計(jì)表格
var grid1=new Ext.grid.GridPanel({
store: store1,
height:300,
cm:cm,
view:new Ext.grid.GroupingView(),
renderTo:"grid1"
});
5、代碼清單如下,效果圖如圖9所示。
<html xmlns="http://www.w3.org/1999/xhtml" >
<head id="Head1" runat="server">
<title>分組表格控件</title>
<link rel="stylesheet" type="text/css" href="../resources/css/ext-all.css" href="resources/css/ext-all.css" />
<script type="text/javascript" src="../adapter/ext/ext-base.js" src="adapter/ext/ext-base.js"></script>
<script type="text/javascript" src="../ext-all.js" src="ext-all.js"></script>
<script type="text/javascript"><!--
Ext.onReady(function(){
var sm=new Ext.grid.CheckboxSelectionModel();
var cm=new Ext.grid.ColumnModel([
new Ext.grid.RowNumberer(),
sm,
{header:'編號(hào)',dataIndex:'id',width:40,sortable:true},
{header:'性別',dataIndex:'sex',width:180},
{header:'名稱',dataIndex:'name',width:200},
{header:'描述',dataIndex:'desn',width:200}
]);
var data=[
['1','male','name1','desn1'],
['2','male','name2','desn1'],
['3','female','name3','desn1'],
['4','male','name4','desn1'],
['5','female','name5','desn1'],
['6','male','name6','desn1'],
['7','male','name7','desn1']
];
var store1= new Ext.data.GroupingStore({
proxy:new Ext.data.MemoryProxy(data),
reader:new Ext.data.ArrayReader({},[
{name:'id'},
{name:'sex'},
{name:'name'},
{name:'desn'}
]),
groupField:'sex',
sortInfo:{field:'id',direction:"ASC"}
});
store1.load();
var grid1=new Ext.grid.GridPanel({
store: store1,
height:300,
cm:cm,
view:new Ext.grid.GroupingView(),
renderTo:"grid1"
});
});
// --></script>
</head>
<body>
<form id="form1" runat="server">
<div id="grid1">
</div>
</form>
</body>
</html>
圖9 分組表格
六、可拖放的表格
首先我們看圖10的效果圖:
圖10 可拖放的表格
注意圖10四周的藍(lán)色細(xì)條,把鼠標(biāo)放到上面,就可以用拖放改變表格的高度和寬度,實(shí)現(xiàn)這一效果并不難,也不需要對(duì)寫好的Grid做大的修改,只要在原先的基礎(chǔ)上添加如下代碼:
var rz=new Ext.Resizable('grid1',{
wrap:true,
minHeight:100,
pinned:true,
handles:'all'
});
rz.on('resize',grid1.syncSize,grid1);
注意:
(1) Resizable必須放在render之后,否則就會(huì)出現(xiàn)問題;
(2) handles:'all'代表可以向所有放心拖動(dòng)表格
七、Grid與右鍵菜單
Grid提供了四個(gè)與右鍵菜單相關(guān)的事件:
(1) contextmenu:全局性的右鍵事件;
(2)cellcontextmenu:單元格上的右鍵事件
(3)rowcontextmenu:行上的右鍵事件
(4)headercontextmenu:表頭的右鍵事件
以下代碼我們實(shí)現(xiàn)一個(gè)行上的右鍵事件,代碼清單如下,效果圖如11所示
var contextmenu=new Ext.menu.Menu({
id:'theContextMenu',
items:[{
text:'查看詳情',
handler:function(){
}
}]
});
grid1.on("rowcontextmenu",function(grid,rowIndex,e){
e.preventDefault();
grid1.getSelectionModel().selectRow(rowIndex);
contextmenu.showAt(e.getXY());
});
圖11 右鍵菜單
- Android自定義DataGridView數(shù)據(jù)表格控件
- 在web中js實(shí)現(xiàn)類似excel的表格控件
- 最棒的Angular2表格控件
- ASP.NET Table 表格控件的使用方法
- 左側(cè)是表頭的JS表格控件(自寫,網(wǎng)上沒有的)
- Android自定義表格控件滿足人們對(duì)視覺的需求
- jquery miniui 教程 表格控件 合并單元格應(yīng)用
- JQuery FlexiGrid的asp.net完美解決方案 dotNetFlexGrid-.Net原生的異步表格控件
- javascript表格控件:Chgrid,簡(jiǎn)化型
- 詳解能在多種前端框架下使用的表格控件
相關(guān)文章
解決Extjs 4 Panel作為Window組件的子組件時(shí)出現(xiàn)雙重邊框問題
Extjs的Panel和Window等組件在默認(rèn)情況下是帶邊框的,通常情況下,單獨(dú)使用沒有什么關(guān)系,但是將Panel作為Window組件的子組件時(shí)就會(huì)出現(xiàn)雙重邊框的現(xiàn)象于是想辦法將兩重邊框去掉,變成單邊框,感興趣的朋友可以了解下2013-01-01Extjs3.0 checkboxGroup 動(dòng)態(tài)添加item實(shí)現(xiàn)思路
Extjs3.0中的CheckboxGroup默認(rèn)不能動(dòng)態(tài)添加item,如需要數(shù)據(jù)動(dòng)態(tài)創(chuàng)建,試著創(chuàng)建整個(gè)CheckboxGroup,而不是動(dòng)態(tài)添加item,具體實(shí)現(xiàn)如下,感興趣的朋友可以了解下2013-08-08extjs grid設(shè)置某列背景顏色和字體顏色的方法
extjs grid設(shè)置某列背景顏色和字體顏色的方法,需要的朋友可以參考下。2010-09-09Extjs中的GridPanel隱藏列會(huì)顯示在menuDisabled中解決方法
在Extjs中的GridPanel會(huì)有這樣的情況,隱藏列會(huì)顯示在menuDisabled中,但是這個(gè)一般沒有什么用處,只是用于后臺(tái)取值的作用,感興趣的朋友可以了解下啊,希望本文對(duì)你有所幫助2013-01-01Extjs列表詳細(xì)信息窗口新建后自動(dòng)加載解決方法
有時(shí)候我們?cè)谛陆斜碇械囊豁?xiàng)后需要進(jìn)入立刻進(jìn)入詳細(xì)信息的編輯頁(yè)面,為了使得操作簡(jiǎn)便,一般設(shè)定自動(dòng)導(dǎo)向。2010-04-04ExtJs 學(xué)習(xí)筆記基礎(chǔ)篇 Ext組件的使用
昨天剛接觸到Extjs,簡(jiǎn)單寫了篇學(xué)習(xí)筆記,今天繼續(xù)。2008-12-12