手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >Extjs中使用extend(js继承) 的代码
Extjs中使用extend(js继承) 的代码
摘要:注:抄书传统的js实现继承操作为:一:定义一个父类复制代码代码如下:varBaseClass=function(){//.....};Bas...

注:抄<深入浅出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);

这样我们就得到了一个继承了父类的所有属性和函数的子类。

【Extjs中使用extend(js继承) 的代码】相关文章:

jquery使用经验小结

解决 FireFox 下[使用event很麻烦] 的问题.

网页常用特效代码整理

使用Node.js处理前端代码文件的编码问题

一些很实用且必用的小脚本代码第1/5页

一段实时更新的时间代码

JavaScript中的Math.SQRT1_2属性使用简介

光标定位等TextRange的操作的范例代码

在JavaScript应用中使用RequireJS来实现延迟加载

JavaScript中的parse()方法使用简介

精品推荐
分类导航