由实例出发看看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.  * licensing@extjs.com 
  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,其他的没啥可说的了,打完收工。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 非常抱歉,我是一名语言模型AI,无法直接回答问题。但是,我可以告诉您,C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植等特点,被广泛应用于系统软件、嵌入式系统、游戏开发等领域。经典200道实例是一本C语言编程实例集合,包含基础例题100道和进阶例题100道,适合初学者和进阶者学习和练习。如果您有具体的问题或需求,欢迎随时向我提问。 ### 回答2: C语言——经典200道实例是一本讲述C语言编程实例的书籍,它共包含基础例题100道和进阶例题100道。这些实例从简单到复杂、从基础到深入地介绍了C语言的各个方面。 基础例题100道主要介绍了C语言的基本语法、数据类型、流程控制、函数等知识点。这些实例中涵盖了最基本的编程技巧和逻辑思考方式,让读者可以逐步了解C语言的编程思路。例如,第4题要求编写程序,在屏幕上输出Hello, world!,这是C语言中最基本的程序实例。而第28题则要求编写程序,判断输入的数字是奇数还是偶数,是典型的流程控制程序。 进阶例题100道则涵盖了更加复杂的编程技巧和算法思想。这些实例中有些需要用到高级数据类型,例如指针和结构体,有些需要用到高级算法思想,例如递归和动态规划等。例如,第145题要求编写程序,实现字符串的逆序输出和复制,这需要用到指针和字符串函数。而第190题则要求编写程序,使用动态规划算法解决斐波那契数列问题,是典型的算法实例。 总的来说,C语言——经典200道实例是一本非常实用的C语言编程教材,它通过大量实例的介绍,让读者可以掌握C语言的基础知识和进阶技巧,从而能够熟练地运用C语言进行编程。无论是初学者还是有一定C语言编程经验的读者,都可以受益于这本书的学习。 ### 回答3: C语言是计算机科学教育中的重要基础语言,也是编程语言入门的首选。而“c语言——经典200道实例【基础例题100道——进阶例题100道】”这本书对于c语言初学者来说是一本极好的练习题集。它包含了100个基础例题和100个进阶例题,涵盖了c语言中的各种语法和语义知识,可以很好地帮助初学者快速提高编程能力。 在基础例题方面,这本书从最基本的数据类型、运算符等知识点开始,逐步深入地讲解了if语句、for循环、while循环、数组、字符串、函数等c语言常用语法和概念,其中的例题非常全面、典型且有针对性,可以让初学者更好地掌握语法和提高编程能力。 在进阶例题方面,这本书则进一步提高了编程难度和思维难度,更加侧重于深入理解c语言的编程思想和实践问题。比如,它包括了递归、指针、二维数组、动态内存分配等比较复杂的概念和应用,这些内容可以更加全面地帮助初学者掌握基础知识,并且在实践中提高自己的思维能力。 总的来说,“c语言——经典200道实例【基础例题100道——进阶例题100道】”这本书是一本非常优秀而且实用的书籍,它能够帮助初学者快速提高编程能力,掌握c语言的核心概念,并且为其未来在计算机语言和编程领域的发展打下坚实的基础。如果你想要对c语言进行系统的学习和实践,这本书是一个非常好的起点和参考。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值