由實例出發看看Ext——《Property Grid》

在做eclipse插件時經常會用的屬性列表,也沒有做好記錄,現在都不知道是怎麼做的了,只是覺得當時做起來十分麻煩,因爲要跟編輯器中的對象對應。
在用Ext做前一個項目時從來沒有用到過Property Grid,看了Ext所給的Property Grid示例感覺非常簡單,所以在這裏說說。

上圖和代碼:

Js代碼  收藏代碼
  1. /*! 
  2.  * Ext JS Library 3.2.1 
  3.  * Copyright(c) 2006-2010 Ext JS, Inc. 
  4.  * [email protected] 
  5.  * http://www.extjs.com/license 
  6.  */  
  7. Ext.onReady(function(){  
  8.       
  9.     var propsGrid = new Ext.grid.PropertyGrid({  
  10.         renderTo: 'prop-grid',  
  11.         width: 300,  
  12.         autoHeight: true,  
  13.         propertyNames: {  
  14.             tested: 'QA',  
  15.             borderWidth: 'Border Width'  
  16.         },  
  17.         source: {  
  18.             '(name)''Properties Grid',  
  19.             grouping: false,  
  20.             autoFitColumns: true,  
  21.             productionQuality: false,  
  22.             created: new Date(Date.parse('10/15/2006')),  
  23.             tested: false,  
  24.             version: 0.01,  
  25.             borderWidth: 1  
  26.         },  
  27.         viewConfig : {  
  28.             forceFit: true,  
  29.             scrollOffset: 2 // the grid will never have scrollbars  
  30.         }  
  31.     });  
  32.   
  33.     // simulate updating the grid data via a button click  
  34.     new Ext.Button({  
  35.         renderTo: 'button-container',  
  36.         text: 'Update source',  
  37.         handler: function(){  
  38.             propsGrid.setSource({  
  39.                 '(name)''Property Grid',  
  40.                 grouping: false,  
  41.                 autoFitColumns: true,  
  42.                 productionQuality: true,  
  43.                 created: new Date(),  
  44.                 tested: false,  
  45.                 version: 0.8,  
  46.                 borderWidth: 2  
  47.             });  
  48.         }  
  49.     });  
  50. });  

代碼十分簡短

主要是這一部分

Js代碼  收藏代碼
  1. source: {  
  2.     '(name)''Properties Grid',  
  3.     grouping: false,  
  4.     autoFitColumns: true,  
  5.     productionQuality: false,  
  6.     created: new Date(Date.parse('10/15/2006')),  
  7.     tested: false,  
  8.     version: 0.01,  
  9.     borderWidth: 1  
  10. },  
  11.   
  12.   
  13. propertyNames: {  
  14.     tested: 'QA',  
  15.     borderWidth: 'Border Width'  
  16. },  
  17.   
  18.   
  19. viewConfig : {  
  20.     forceFit: true,  
  21.     scrollOffset: 2 // the grid will never have scrollbars  
  22. }  

 

這個例子用到的是Ext.grid.PropertyGrid類,該類也是一個Grid不過他與之前說的GridPanel有所不同,他是專爲顯示屬性列表設計的。
正如上面給出的三段代碼,設置好source、propertyNames、viewConfig就可以顯示了。

source,要求設置一個對象,實際上就是屬性名稱和值的對應。屬性名稱可以用“''”引起來也可以不用,不過有特殊字符的就一定要引了。PropertyGrid可以根據設置的值類型自動選擇修改值的控件;當然如果對他爲你選擇的控件不滿意,你可以修改它,使用customEditors屬性來設置某一個屬性值的編輯控件,這個以後有機會可能會詳細說明。

propertyNames,通過該屬性設置屬性名,這裏是一個source中定義的名稱與實際顯示名稱的對應。在例子中設置了tested和borderWidth,讓他們在顯示時不顯示他們的原名,而是顯示後面點以的名稱。

viewConfig,顯示配置。這裏設置的兩個屬性是:forceFit,自動讓Grid中的所有列按原有寬度比例重拍,佔滿整個Grid;scrollOffset設置滾動條佔用的寬度。viewConfig接受的對象實際是Ext.grid.GridView類型的對象,具體還能設置哪些屬性可以看該類的API。

 

例子中還有一個按鈕,功能是重新設置PropertyGrid中的各個屬性。

ok,其他的沒啥可說的了,打完收工。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章