乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      ExtJS的使用方法匯總—配置和表格控件使用

       青_春 2015-11-19

      在網(wǎng)上差一些關于ExtJS的相關資料,看到這篇博客寫的不錯,拿出來分享一下!

      博客文章ExtJS的使用方法匯總(1)——配置和表格控件使用
                    ExtJS的使用方法匯總(2)——表單與輸入控件

      原文鏈接http://blog.csdn.net/rocket5725/article/details/4535323

      第二篇博客http://blog.csdn.net/rocket5725/article/details/4538843

      原文如下

      ExtJS時一套AJAX控件,本人認為它是目前我見過最好最美的JS控件庫,所以非常有學習和使用價值,如果你還沒有接觸過ExtJS或者壓根對其不感興趣,那么沒有必要看下去了,ExtJS是一套完整的RIA解決方案,也因為功能完整造成了ext-all.js有400多k,由于是基于JS和CSS的功能實現(xiàn),對客戶端機器性能也有一定的要求,即不支持IE6以下的版本。如果您的項目對網(wǎng)頁響應時間有嚴格的限制,或者客戶端操作系統(tǒng)過于陳舊,一定不要選擇ExtJS。

      本文主要是介紹ExtJS的下載和配置以及一些簡單的使用方法。目前最新版本為3.0,但是本文主要介紹2.2版本。

      一、ExtJS下載以及配置

      1、下載地址:www./(這是官網(wǎng),大家可以選擇自己喜歡的版本下載)

      2、配置過程,假設下載后的目錄為Ext,我們在該目錄下建立我們自己的目錄MyExample(該目錄用于存放你自己寫的代碼),配置過程如下:

      (1) 新建一個頁面文件Helloworld.html

      (2) 在<head>和</head>之間添加如下代碼:

      1. <link rel="stylesheet" type="text/css" href="../resources/css/ext-all.css" />  
      2. <script type="text/javascript" src="../adapter/ext/ext-base.js"></script>  
      3. <script type="text/javascript" src="../ext-all.js"></script>  
      4. <script type="text/javascript">  
      5.     Ext.onReady(function(){  
      6.         Ext.MessageBox.alert('HelloWorld','Hello World');  
      7.     })  
      8. </script>  

       

      (3) 這里注意<script></script>不能用</script>取代

      (4) js的導入順序不要更改

      (3) 如果彈出一個HelloWorld的對話框,則代表配置成功。

      二、表格控件Grid的使用

      EXT中的表格功能非常強大,包括排序、緩存、拖動、隱藏某一列、自動顯示行號、列匯總、單元格編輯等使用功能。我們首先介紹如何制作一個簡單的Grid。

      1、創(chuàng)建表格的列信息:

      1. var cm=new Ext.grid.ColumnModel([  
      2.      {header:'編號',dataIndex:'id'},  
      3.      {header:'名稱',dataIndex:'name'},  
      4.      {header:'描述',dataIndex:'desn'}  
      5.  ]);  

       

      2、添加數(shù)據(jù)信息:

      1. var data=[  
      2.       ['1','name1','desn1'],  
      3.       ['2','name1','desn1'],  
      4.       ['3','name1','desn1'],  
      5.       ['4','name1','desn1'],  
      6.       ['5','name1','desn1']  
      7.   ];  

        

       

      3、創(chuàng)建數(shù)據(jù)存儲對象:

      1. var ds=new Ext.data.Store({  
      2.       proxy:new Ext.data.MemoryProxy(data),  
      3.       reader:new Ext.data.ArrayReader({},[  
      4.           {name:'id'},  
      5.           {name:'name'},  
      6.           {name:'desn'}  
      7.       ])  
      8.   });  
      9.   ds.load();//這個相當?shù)闹匾?/span>  

       

      4、表格的列模型定義好了,原始數(shù)據(jù)和數(shù)據(jù)的轉(zhuǎn)換也已經(jīng)完成,剩下的只需要把它們裝配在一起,我們的Grid就創(chuàng)建成功了。

      1. var grid=new Ext.grid.GridPanel({  
      2.      renderTo:"grid",  
      3.      store: ds,  
      4.      height:600,  
      5.      cm:cm                  
      6.  });  

       

      5、注意:Ext.grid.Grid的renderTo屬性指示EXT將表格渲染到什么地方,所以,在HTML里應該有一個<div id='grid'></div>與之對應。

      6、所有代碼清單如下(已通過測試):

       

      實驗效果圖如圖1所示

      1

      圖1 一個簡單的Grid

      三、表格控件Grid的功能詳解

      第二部分簡單介紹了如何創(chuàng)建簡單的Grid,本章將對Grid的功能進行詳細的分析。

      3.1 部分屬性功能

      1、默認情況下,Grid是可以拖放列,也可以改變列的寬度,如果要禁用這兩個功能,在定義Grid對象時分別設置enableColumnMove和enableColumnResize為false即可。

      2、如果希望顯示斑馬線效果,可以加上stripeRows:true

      3、Grid還支持一種讀取數(shù)據(jù)時的遮罩和提示功能,設置屬性loadMask:true,在store.load()完成之前一直會顯示"Loading…"

      3.2 自主決定每列的寬度

      1、如果要定義寬度,只要設置該列的width屬性即可,如下面的代碼所示。效果圖如圖2所示。

      1. var cm=new Ext.grid.ColumnModel([  
      2.                 {header:'編號',dataIndex:'id',width:60},  
      3.                 {header:'名稱',dataIndex:'name',width:180},  
      4.                 {header:'描述',dataIndex:'desn',width:200}  
      5.             ]);  

        

       

      2

      圖2 自定義每列的寬度

      2、這樣需要自己去計算每列的寬度,如果想讓每列自動填滿Grid,只需要viewConfig中的forceFit即可。使用forceFit后,Grid會根據(jù)你在cm里設置的width按比例分配,非常智能。實現(xiàn)代碼如下:

      1. var grid=new Ext.grid.GridPanel({  
      2.                 renderTo:"grid",  
      3.                 stripeRows:true,//斑馬線效果   
      4.                 loadMask:true,  
      5.                 store: ds,  
      6.                 height:600,  
      7.                 cm:cm,  
      8.                 viewConfig:{  
      9.                     forceFit:true  
      10.                 }                  
      11.             });   

       

      3、我們也可以考慮autoExpandColumn,它可以讓指定列的寬度自動伸展,從而填充整個表格。代碼如下

      1. var grid=new Ext.grid.GridPanel({  
      2.                 renderTo:"grid",  
      3.                 stripeRows:true,//斑馬線效果   
      4.                 loadMask:true,  
      5.                 store: ds,  
      6.                 height:600,  
      7.                 cm:cm,  
      8.                 autoExpandColumn:'desn'  
      9. //                viewConfig:{   
      10. //                    forceFit:true   
      11. //                }                   
      12.             });   

       

      注意:autoExpandColum只能指定一列的id,注意,必須是id,原來我們設置的cm里面都沒有id,現(xiàn)在為了使用autoExpandColumn,要給cm的desn設置id.于是在渲染時desn就可以自動延伸,否則會出錯。

      1. var cm=new Ext.grid.ColumnModel([  
      2.                 {header:'編號',dataIndex:'id',width:60},  
      3.                 {header:'名稱',dataIndex:'name',width:180},  
      4.                 {id:'desn',header:'描述',dataIndex:'desn',width:200}  
      5.             ]);  

       

      3.3 讓Grid支持按列排序

      在EXT中可以很方便地實現(xiàn)排序功能,只需要在定義列模型時增加sortable屬性,如下面代碼所示:

      1. var cm=new Ext.grid.ColumnModel([  
      2.                 {header:'編號',dataIndex:'id',width:60,sortable:true},  
      3.                 {header:'名稱',dataIndex:'name',width:180},  
      4.                 {id:'desn',header:'描述',dataIndex:'desn',width:200}  
      5.             ]);  

       

      效果圖如圖3所示

      3

      圖3 按列排序效果

       

      3.4 顯示時間類型數(shù)據(jù)

      盡管返回的JSON里都是數(shù)字和字符串,但是在EXT中我們同樣可以從后臺取得日期類型的數(shù)據(jù),然后交給Grid進行格式化。

      1、首先定義一組數(shù)據(jù),其中最后一列是日期格式的數(shù)據(jù)。

      1. var data=[  
      2.                 ['1','name1','desn1','2009-09-17T02:58:04'],  
      3.                 ['2','name2','desn1','2009-09-17T02:58:04'],  
      4.                 ['3','name3','desn1','2009-09-17T02:58:04'],  
      5.                 ['4','name4','desn1','2009-09-17T02:58:04'],  
      6.                 ['5','name5','desn1','2009-09-17T02:58:04']  
      7.             ];  

       

      2、接著我們在reader里面增加一行配置,除了設置name以外,還設置了type和dateFormat兩個屬性。代碼如下:

      1. var store1= new Ext.data.Store({  
      2.                 proxy:new Ext.data.MemoryProxy(data),  
      3.                 reader:new Ext.data.ArrayReader({},[  
      4.                     {name:'id'},  
      5.                     {name:'name'},  
      6.                     {name:'desn'},  
      7.                     {name:'date',type:'date',dateFormat:'Y-m-dTH:i:s'}  
      8.                 ])  
      9.             });  

        

       

      3、同樣的,我們還需要在cm里面增加一行配置:

      1. var cm=new Ext.grid.ColumnModel([  
      2.                 {header:'編號',dataIndex:'id',width:60,sortable:true},  
      3.                 {header:'名稱',dataIndex:'name',width:180},  
      4.                 {id:'desn',header:'描述',dataIndex:'desn',width:200},  
      5.                 {header:'時間',dataIndex:'date',type:'date',renderer:Ext.util.Format.dateRenderer('Y年m月d日')}  
      6.             ]);  

       

      4、代碼詳細信息如下所示,效果圖如圖4所示。

        

       

      4

      圖4 具有時間數(shù)據(jù)的Grid

       

      3.5 自動顯示行號和復選框

      實際上,行號和復選框都是renderer的延伸。當然,復選框的功能要復雜得多。

      1、自動顯示行號:修改列模型cm,加入RowNumberer對象;

      2、復選框:我們創(chuàng)建一個CheckboxSelectionModel()

      3、詳細代碼如下,效果圖如圖5所示

      1. var sm=new Ext.grid.CheckboxSelectionModel();  
      2.             var cm=new Ext.grid.ColumnModel([  
      3.                 new Ext.grid.RowNumberer(),  
      4.                 sm,  
      5.                 {header:'編號',dataIndex:'id',width:40,sortable:true},  
      6.                 {header:'名稱',dataIndex:'name',width:180},  
      7.                 {id:'desn',header:'描述',dataIndex:'desn',width:200},  
      8.                 {header:'時間',dataIndex:'date',type:'date',renderer:Ext.util.Format.dateRenderer('Y年m月d日')}  
      9.             ]);  

       

      5

      圖5 自動行號以及復選框效果圖

       

      3.6 表格分頁

      Grid控件對性能要求較高,如果在一個Grid里面顯示上千條記錄,效率會有明顯下降,所以必須考慮分頁問題。

      1、為Grid添加分頁工具條:在前面代碼的基礎上修改grid代碼:

      1. var grid1=new Ext.grid.GridPanel({  
      2.                 renderTo:"grid1",  
      3.                 stripeRows:true,//斑馬線效果   
      4.                 loadMask:true,  
      5.                 store: store1,  
      6.                 height:200,  
      7.                 cm:cm,                  
      8.                 viewConfig:{  
      9.                     forceFit:true  
      10.                 },  
      11.                 bbar:new Ext.PagingToolbar({  
      12.                     pageSize:10,  
      13.                     store: store1,  
      14.                     displayInfo:true,  
      15.                     displayMsg:'顯示第{0}條到{1}條記錄,一共{2}條',  
      16.                     emptyMsg:"沒有記錄"  
      17.                 })                  
      18.             });  

       

      2、效果圖如圖6所示:

      6

      圖6 添加分頁工具條

      3、如果要真正實現(xiàn)分頁,還需要通過后臺腳本獲得分頁數(shù)據(jù),這部分在此不再給出 

      四、可編輯表格控件——EditorGrid

      EditorGrid可以直接在表格里面執(zhí)行添加、刪除、修改、查找等功能,然后一次性保持。還有可以動態(tài)修改某個單元格,這些單元格我們先暫時不能為空,保存時會進行檢測,為空就無法保存,驗證信息會給予提示。

      4.1 制作一個簡單的EditorGrid

      1、定義列,代碼如下:

      1. var cm=new Ext.grid.ColumnModel([  
      2.                 {header:'編號',dataIndex:'id',width:40,editor:new Ext.grid.GridEditor(  
      3.                     new Ext.form.TextField({  
      4.                         allowBlank:false  
      5.                     })  
      6.                 )},  
      7.                 {header:'名稱',dataIndex:'name',width:180,editor:new Ext.grid.GridEditor(  
      8.                     new Ext.form.TextField({  
      9.                         allowBlank:false  
      10.                     })  
      11.                 )},  
      12.                 {id:'desn',header:'描述',dataIndex:'desn',width:200},  
      13.                 {header:'時間',dataIndex:'date',type:'date',renderer:Ext.util.Format.dateRenderer('Y年m月d日')}  
      14.             ]);   

       

      2、定義grid,注意此時是EditorGridPanel.

      1. var grid1=new Ext.grid.EditorGridPanel({  
      2.                 renderTo:"grid1",  
      3.                 store: store1,  
      4.                 height:200,  
      5.                 clicksToEdit:1,  
      6.                 cm:cm           
      7.             });   

       

      3、默認情況下,需要雙擊單元格才能激活編輯器,從而進行修改,不過,也可以給Grid配置clickToEdit:1,這樣就可以單擊單元格激活編輯器,從而進行修改,如圖7所示:

      7

      圖7 通過單擊修改單元格

       

      五、屬性表格——PropertyGrid

      屬性表格擴展自EditorGridPanel,所以可以直接編輯右邊的內(nèi)容,注意:只有右邊的,即使你單擊左邊的單元格,編輯器也會出現(xiàn)在右邊。

      定義的方法如下:

      1. <mce:script type="text/javascript"><!--  
      2.         Ext.onReady(function(){  
      3.             var grid=new Ext.grid.PropertyGrid({  
      4.                 title:"屬性表格",  
      5.                 autoHeight:true,  
      6.                 width:400,  
      7.                 renderTo:'grid1',  
      8.                 source:{  
      9.                     "名字":"薛敬明",  
      10.                     "創(chuàng)建時間":new Date(Date.parse('12/15/2009')),  
      11.                     "是否有效":false,  
      12.                     "版本號":.01,  
      13.                     "描述":"估計沒有啥說的"  
      14.                 }  
      15.             });   
      16.                      
      17.         });  
      18.       
      19. // --></mce:script>  

       

      效果圖如圖8所示:

      8

      圖8 屬性表格效果圖

      六、分組表格——Group

      分組表格就是在普通表格的基礎上,根據(jù)某一列的數(shù)據(jù)將表格中的數(shù)據(jù)分組顯示的表格控件。

      1、首先定義一組數(shù)據(jù)

      1. var data=[  
      2.                 ['1','male','name1','desn1'],  
      3.                 ['2','male','name2','desn1'],  
      4.                 ['3','female','name3','desn1'],  
      5.                 ['4','male','name4','desn1'],  
      6.                 ['5','female','name5','desn1'],  
      7.                 ['6','male','name6','desn1'],  
      8.                 ['7','male','name7','desn1']  
      9.             ];  

       

      2、創(chuàng)建表格的列信息

      1. var sm=new Ext.grid.CheckboxSelectionModel();  
      2.             var cm=new Ext.grid.ColumnModel([  
      3.                 new Ext.grid.RowNumberer(),  
      4.                 sm,  
      5.                 {header:'編號',dataIndex:'id',width:40,sortable:true},  
      6.                 {header:'性別',dataIndex:'sex',width:180},  
      7.                 {header:'名稱',dataIndex:'name',width:200},  
      8.                 {header:'描述',dataIndex:'desn',width:200}  
      9.             ]);    

       

      3、創(chuàng)建數(shù)據(jù)存儲對象

      1. var store1= new Ext.data.GroupingStore({  
      2.                 proxy:new Ext.data.MemoryProxy(data),  
      3.                 reader:new Ext.data.ArrayReader({},[  
      4.                     {name:'id'},  
      5.                     {name:'sex'},  
      6.                     {name:'name'},  
      7.                     {name:'desn'}  
      8.                 ]),                  
      9.                 groupField:'sex',  
      10.                 sortInfo:{field:'id',direction:"ASC"}  
      11.             });   
      12.             store1.load();  

       

      4、設計分組設計表格

      1. var grid1=new Ext.grid.GridPanel({  
      2.                 store: store1,  
      3.                 height:300,  
      4.                 cm:cm,                  
      5.                 view:new Ext.grid.GroupingView(),  
      6.                 renderTo:"grid1"                
      7.             });  

       

      5、代碼清單如下,效果圖如圖9所示。

       

       

      9

      圖9 分組表格

       

      六、可拖放的表格

      首先我們看圖10的效果圖:

      10

      圖10 可拖放的表格

      注意圖10四周的藍色細條,把鼠標放到上面,就可以用拖放改變表格的高度和寬度,實現(xiàn)這一效果并不難,也不需要對寫好的Grid做大的修改,只要在原先的基礎上添加如下代碼:

      1. var rz=new Ext.Resizable('grid1',{  
      2.                 wrap:true,  
      3.                 minHeight:100,  
      4.                 pinned:true,  
      5.                 handles:'all'  
      6.             });  
      7.             rz.on('resize',grid1.syncSize,grid1);  

       

      注意:

      (1) Resizable必須放在render之后,否則就會出現(xiàn)問題;

      (2) handles:'all'代表可以向所有放心拖動表格 

      七、Grid與右鍵菜單

      Grid提供了四個與右鍵菜單相關的事件:

      (1) contextmenu:全局性的右鍵事件;

      (2)cellcontextmenu:單元格上的右鍵事件

      (3)rowcontextmenu:行上的右鍵事件

      (4)headercontextmenu:表頭的右鍵事件

      以下代碼我們實現(xiàn)一個行上的右鍵事件,代碼清單如下,效果圖如11所示

      1. var contextmenu=new Ext.menu.Menu({  
      2.                 id:'theContextMenu',  
      3.                 items:[{  
      4.                     text:'查看詳情',  
      5.                     handler:function(){  
      6.                     }  
      7.                 }]  
      8.             });  
      9.             grid1.on("rowcontextmenu",function(grid,rowIndex,e){  
      10.                 e.preventDefault();  
      11.                 grid1.getSelectionModel().selectRow(rowIndex);  
      12.                 contextmenu.showAt(e.getXY());  
      13.             });   

       

      11

      圖11 右鍵菜單

       
      *************************************************
      在測試功能時,注意ExtJS的版本,本文介紹的是2.2版本,我自己練習用的是3.4.0,在功能實現(xiàn)上對于屬性、方法、事件的使用有很大的不同,如在3.4.0的版本中測試這些效果,第一個顯示Grid的效果就無法實現(xiàn),還是理解大概的邏輯,具體的調(diào)用還是查官方給的ExtJS的API文檔最好。好像最新的版本是4.1.1。
      對于本文的處理:
      1. var grid=new Ext.grid.GridPanel({  
      2.      renderTo:"grid",  
      3.      store: ds,  
      4.      height:600,  
      5.      cm:cm                  
      6.  });  
      ******************
      var grid=new Ext.grid.GridPanel({
         renderTo:"grid",//rendTo屬性指示將表格渲染到什么地方
         store:ds,   
         width:500,//限定寬度
         colModel:cm1,
         stripeRows:true,//斑馬線效果
         loadMask:true,//讀取數(shù)據(jù)遮罩和提示,Loading....
         enableColumnMove:false,//取消列的拖放
         enableColumnResize:false,//取消列的大小改變
         viewConfig:{
          forceFit:true//自動填滿Grid,填滿父容器"grid"的大小,
         }
        });
      其他的問題,跟著ExtJS API文檔查吧!祝,大家編程愉快!

        本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約