js继承的方法总结(prototype,call,apply) January 24, 2020 **首先了解下prototype** 1,在js一切皆对象中,了解到凡是通过`new function()`创建的对象都是函数对象,否则就是普通对象。 2,普通对象没有`prototype`属性但有`_proto_`属性,函数对象都包含`prototype`和`_proto_`属性 3,原型对象的主要作用就是为了实现继承。 4,使用原型继承可以达到:1,可以动态的给所需对象设置属性和方法 。 2,子类继承父类,可以使用和享有父亲的所有属性和方法。 ```xml ``` ### 2,call和apply **首先了解下call和apply** ```css obj.call(thisObj, arg1, arg2, ...); obj.apply(thisObj, [arg1, arg2, ...]); ``` ** 归根揭底就是一句话: 把obj的this绑定到thisObj上,这时候thisObj具备了(或者说继承了)obj的属性和方法,然后在thisObj的执行环境里面执行obj的属性和方法,绑定后会立即执行函数 ** 1,apply和call 本来就是为了扩展函数的作用域而生的,换句话说就是为了改变this的指向存在的 2,当一个object没有某种方法,但是其他的有,我们可以借助call和apply来用其他对象的方法来做操作,也可以传参数 ```xml