本文地址: http://blog.csdn.net/sushengmiyan/article/details/38479079javascript
本文做者:sushengmiyanjava
-------------------------------------------------------------资源连接-----------------------------------------------------------------------编程
翻译来源 Sencha Cmd官方网站: http://www.sencha.com/products/extjs/up-and-running/the-class-systemapp
------------------------------------------------------------------------------------------------------------------------------------------------框架
本篇指导旨在给想要建立或者从EXT JS 4.X或者EXT JS 5.X继承已有类的任何开发者的。异步
-------函数
EXT JS 5自带了有超过300的类,到目前为止有200多万的开发者在使用extjs开发,他们来自不一样的地方,有不一样的背景。因此这样说来,在提供一份公共代码结构上咱们就面临着一个巨大的挑战,这些代码结构是:学习
1.你们都熟悉了解,简单容易学习网站
2.开发迅速,调试方便,部署的时候也没有痛苦this
3.有组织的,可扩展的,而且是可维护的
JavaScript是面向原型的类语言,其中一个最强大的功能就是自由,有好多的解决方案,可使用不一样的编码风格还有技术问题,可是这样就会以不可预知为代价了。没有一个统一的结构,javascript代码就很难理解,很难维护而且很差复用。
另外一方面,基于类的编程仍然是最流行的面向对象的编程模式,基于类的语言一般须要强类型,封装和标准的编码惯例,经过让开发人员坚持大量的原则,代码更多是可预测的,可扩展和可伸缩。然而,这个模型没有JavaScript的动态能力。
每一个方法都有优势和缺点,可是咱们能够保持好的而坏的部分同时隐藏?答案是确定的,你能够在Ext JS找到解决方案。
MyCompany.useful_util.Debug_Toolbar这个是被推荐的
MyCompany.util.Base64这个是能够接受的
MyCompany.data.CoolProxy MyCompany.Application顶级名称空间和实际的类名应该驼峰模式其它一切应该都小写,例如:
MyCompany.form.action.AutoLoad不是使用sencha生成的类尽可能不要使用Ext做为顶级空间。缩略词也应该遵照驼峰预定定,如:
var MyWindow = Ext.extend(Object, { ... });这种方法很容易遵循以建立一个新的类继承自另外一个。除了直接继承,咱们没有 其余方面创造流畅的API 的类。这个排除诸如配置、静态和mixins。咱们稍后将详细回顾这些物品在本指南。
My.cool.Window = Ext.extend(Ext.Window, { ... });在本例中,咱们想咱们新类命名空间,并使其从Ext.window延伸。有两个问题咱们须要解决:
xt.ns('My.cool'); My.cool.Window = Ext.extend(Ext.Window, { ... });第二个问题不容易解决,由于ext.window可能取决于许多其余类。反过来,这些依赖关系可能依赖于其余类的存在。出于这个缘由,Ext JS 4以前编写的应用程序引入整个ext-all.js的形式,无论应用程序是否是只须要一小部分的框架。
Ext.define(className, members, onClassCreated);className:类名
Ext.define('My.sample.Person', { name: 'Unknown', constructor: function(name) { if (name) { this.name = name; } }, eat: function(foodType) { alert(this.name + " is eating: " + foodType); } }); var aaron = Ext.create('My.sample.Person', 'Aaron'); aaron.eat("Salad"); // alert("Aaron is eating: Salad");注意:咱们建立了一个新的My.sample的实例。使用Ext.create()方法。咱们可使用新的关键字(new My.sample.Person())。不过建议获得的习惯老是使用Ext.create由于它容许您利用动态加载。动态加载的更多信息参见入门指南
Ext.define('My.own.Window', { /** @readonly */ isWindow: true, config: { title: 'Title Here', bottomBar: { height: 50, resizable: false } }, applyTitle: function(title) { if (!Ext.isString(title) || title.length === 0) { alert('Error: Title must be a valid non-empty string'); } else { return title; } }, applyBottomBar: function(bottomBar) { if (bottomBar) { if (!this.bottomBar) { return Ext.create('My.own.WindowBottomBar', bottomBar); } else { this.bottomBar.setConfig(bottomBar); } } } }); /** A child component to complete the example. */ Ext.define('My.own.WindowBottomBar', { config: { height: undefined, resizable: true } });这是一个如何使用它的例子:
var myWindow = Ext.create('My.own.Window', { title: 'Hello World', bottomBar: { height: 60 } }); alert(myWindow.getTitle()); // alerts "Hello World" myWindow.setTitle('Something New'); alert(myWindow.getTitle()); // alerts "Something New" myWindow.setTitle(null); // alerts "Error: Title must be a valid non-empty string" myWindow.setBottomBar({ height: 100 }); alert(myWindow.getBottomBar().getHeight()); // alerts 100
Ext.define('Computer', { statics: { instanceCount: 0, factory: function(brand) { // 'this' in static methods refer to the class itself return new this({brand: brand}); } }, config: { brand: null } }); var dellComputer = Computer.factory('Dell'); var appleComputer = Computer.factory('Mac'); alert(appleComputer.getBrand()); // using the auto-generated getter to get the value of a config property. Alerts "Mac"
throw new Error('['+ Ext.getDisplayName(arguments.callee) +'] Some message here');当有错误在使用Ext.define时抛出的时候,你应该查看这个方法还有类的堆栈信息,你能够看下谷歌Chrome中报错的信息以下: