作家
登录

Extjs中使用extend(js继承) 的代码

作者: 来源:www.28hudong.com 2013-03-30 00:31:52 阅读 我要评论

注:抄<深入浅出Extjs>书 传统的js实现继承操作为: 一:定义一个父类 复制代码 代码如下: var BaseClass = function(){ //..... }; BaseClass.prototype.someMethod = function(){ //..... }; BaseClass.prototype.overridenMethod = function(){ //.... } 为BaseClass定义两个函数someMethod 和overridenMethod ,,然后定义一个subClass子类,可以直接从BaseClass中继承所有的属性和函数, 复制代码 代码如下: var subClass = function(){ BaseClass.call(this); }; subClass.prototype = new BaseClass(); subClass.prototype.newMethod = function(){ //... }; subClass.prototype.overridenMethod = function(){ //... } 在上面的代码中,subClass的构造函数首先调用BaseClass的构造函数初始化数据,然后通过subClass.prototype = new BaseClass();这条语句让subClass类获得BaseClass中的所有属性和函数。这样就实现了继承。在此之后我们就可以操作subClass的prototype,为子类添加新的函数或者覆写父类的同名函数。 在EXT中使用Ext.extend()函数实现继承功能的方法: 复制代码 代码如下: var subClass = function(){ subClass.superclass.costructor.call(this); }; Ext.extend(subClass, BaseClass,{ newMethod: function(){ //... }, overridenMethod : function(){ //.... } }); 在Ext.extend()函数通过 subClass.superclass.costructor.call(this);就可以直接调用父类的构造函数。这个函数的第一个参数总是this, 以确保父类的构造函数在子类的作用域里工作。 如果父类的构造函数需要传入参数,我们也就可以将所需要的参数直接传给它,如: subClass.superclass.costructor.call(this, config); 这样我们就得到了一个继承了父类的所有属性和函数的子类。

  推荐阅读

  asp.net网站开发中用jquery实现滚动浏览器滚动条加载数据(类似于腾讯微博)

自从腾讯微博上线以来,基本上就开始用了,一直到现在,作为一个开发人员,也看到了腾讯微博一直在不停的改变,也不知道大家有没有发现,腾讯微博提供两种加载数据的方式,一种是分页,一种是滚动浏览器滚动条加载>>>详细阅读


本文标题:Extjs中使用extend(js继承) 的代码

地址:http://www.17bianji.com/kaifa2/JS/23558.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)