原型继承是js的一种继承方式,简单来说就是构造函数和子构造函数,或者说类和子类之间(当然js中不存在类),唯一的继承传递方式是通过原型,而不是其他语言直接通过extends。所以自己需要手写prototype。其核心是将父类的实例作为子类的原型
var A=function(){ this.a=1; this.b=2; this.add=function(){ console.log(a+b); } } var B=function(){} B.prototype=new A(); B.prototype.c=3; B.prototype.add=function(){ console.log(B.a+B.b+B.c); } var b=new B(); console.log(b.a); console.log(b.b); console.log(b.c);在js中,可以利用构造函数来创建特定类型的对象,其中,有一些原生的构造函数,Object、Array等,所以,当type of Object时,返回的是function。此外,我们还可以创建自定义的构造函数,从而自定义对象的属性以及方法。其核心是将父类的实例作为子类的原型
var A=function(){ this.a=1; this.b=2; this.add=function(){ console.log(a+b); } } var B=new A(); B.c=3; B.add=function () { console.log(B.a+B.b+B.c); } console.log(B.a); console.log(B.b); console.log(B.c); B.add();call与apply的第一个参数都是需要调用的函数对象,在函数体内这个参数就是this的值,剩余的参数是需要传递给函数的值,call与apply的不同就是call传的值可以是任意的,而apply传的剩余值必须为数组。
function A(){ this.a=1; this.b=2; this.add=function(){ console.log(a+b); } } function B(){ A.call(this); this.c=3; this.add=function(){ console.log(this.a+this.b+this.c); } } var b=new B(); console.log(b.a); console.log(b.b); console.log(b.c); b.add();