关于JS的继承
来源:互联网 发布:sqlserver tochar 编辑:程序博客网 时间:2024/06/05 05:45
//继承 : 子类不影响父类,子类可以继承父类的一些功能 ( 代码复用 )
//属性的继承 : 调用父类的构造函数 call
//方法的继承 : for in : 拷贝继承 (jquery也是采用拷贝继承extend)
1拷贝继承
function Person (name){
this.name = name;
}
Person.prototype.showName =function (){
alert(this.name);
}
function Worker(name,job){
Person.call(this,name);
this.job = job;
}
extend(Worker.prototype, Person.prototype);
//如果用Worker.prototype=Person.prototype的话,会造成引用相同的问题
function extend(obj1,obj2){
for(var i in obj2){
obj1[i] = obj2[i]
}
}
var coder = new Worker('magicfly','frontEnd');
coder.showName();
2 类继承
function Person (name){
this.name = name;
}
Person.prototype.showName =function (){
alert(this.name);
}
function Worker(name,job){
Person.call(this,name);
this.job = job;
}
//Worker.prototype = new Person();
// 这样继承会继承父级的不必要属性
function F(){};
F.prototype = Person.prototype;
Worker.prototype = new F();
//通过建立一个临时构造函数来解决 ,也称为代理函数
var coder = new Worker('MAGICFLY','START');
coder.showName();
3 原型继承
var a = {
name : '小明'
};
var b = cloneObj(a);
b.name = '小强';
//alert( b.name );
alert( a.name );
function cloneObj(obj){
var F = function(){};
F.prototype = obj;
return new F();
}
适用情况
拷贝继承: 通用型的 有new或无new的时候都可以
类式继承: new构造函数
原型继承: 无new的对象
- 关于JS的继承
- 关于js继承的文章
- 关于js继承的一些代码
- cocos2d-js中关于继承的细节
- 关于js原型继承的理解
- 关于js继承
- 关于js原型继承
- js关于继承
- 关于js的接口和 继承实现的代码例子
- 关于js继承---Base类的源码解析
- 关于js原型和继承的方法复习
- 关于继承,函数的继承
- 关于继承,函数的继承
- js的继承
- js继承的理解
- Js的继承
- js的继承
- js的原型继承
- Hello World
- Ubuntu下为Firefox安装Adobe Flash Player
- iOS label高度随字数增加而增长
- 写流文件的方式把页面中的数据导到Excel的终极代码
- DbUtils学习(二)
- 关于JS的继承
- Android开发之Action Bar详解
- svn Please execute the 'Cleanup' command.
- 在Linux下的Tengine安装和配置
- 胡博君讲解CSS中注释失效的原因
- java实现中文汉字的首字母排序
- leetcode 166: Fraction to Recurring Decimal
- wordpress开发教程
- 和其他App分享文件(1)设置文件共享