Extjs使用extend(js继承)
2012-03-14 22:31
501 查看
注:抄<深入浅出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);
这样我们就得到了一个继承了父类的所有属性和函数的子类。
传统的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继承) 的代码
- Extjs中使用extend(js继承) 的代码
- extjs的Ext.extend的使用样例(Ext继承)
- 在Angular.js使用组合+依赖注入而不是继承
- 使用Ext实现js的继承,以及扩展Ext组件的思路
- 通过backbone的extend函数又想了一下JS的继承
- 使用JS中的Call方法实现继承和多重继承
- salesforce extendsion and standart component 继承和标准组件的使用
- Node.js 之使用util模块实现events的继承详解
- json.js与ExtJS一起使用的问题
- 使用Ext.extend进行继承的一个有趣的问题
- [js高手之路]Node.js模板引擎教程-jade速学与实战4-模板引用,继承,插件使用
- Js 控件编写 继承:extend、mixin和plugin(一)
- extjs使用一:extjs-base.js无法访问等等问题
- 实现类似EXTJS表格插件 Flexgrid.js GridView中使用的记录
- extjs 使用extend
- ExtJs--11--Ext定义类时,使用混入的配置项,可实现多继承关系
- js 组合继承(使用原型模式和构造函数模式)和原型式继承
- js使用原型实现继承与new一个新对象的方法
- json.js与ExtJS一起使用的问题