函数的继承
2018-12-04 本文已影响28人
优秀的人A
//父类
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传进去
call和apply
//call和apply
//二者都可以改变当前的this,区别在于apply方法要将参数放入数组中在传参
function aa(a,b) {
alert('我的this是' + this + ',我的a是' + a + ',我的b是' + b);
}
aa.call('abc',2,3);
aa.apply('abc',[2,3]);
二者都可以改变当前的this,区别在于apply方法要将参数放入数组中在传参