函数继承

call和apply

function aa(a,b) {
    alert('我的this是' + this + ',我的a是' + a + ',我的b是' + b);
}
aa.call('abc',2,3);
aa.apply('abc',[2,3]);
二者都可以改变当前的this,区别在于apply方法要将参数放入数组中在传参

//父类
function Fclass(name,age) {
    this.name = name;
    this.age = age;
}
//放在原型上所有新的实例可以共有这个函数
Fclass.prototype.showName = function () {
    alert(this.name);
};
Fclass.prototype.showAge = function () {
    alert(this.age);
};
//子类
function Sclass(name,age,job) {
    //如果js想要实现继承的话,就要调用父类call方法,把this传进去
    //属性的继承
    //  Fclass.apply(this,[name,age]);
    Fclass.call(this,name,age);
    this.job = job
}
//方法的继承
Sclass.prototype = new Fclass();
Sclass.prototype.showJob = function () {
    alert(this.job);
};
var chile = new Sclass('Jack',18,'老司机');
chile.showName();
如果js想要实现继承的话,就要调用父类call方法,把this穿进去

你可能感兴趣的:(函数继承)