本文实例讲述了JS中call和apply函数用法。分享给大家供大家参考,具体如下:@H_502_1@
call 函数@H_502_1@
thisObj继承obj的属性和方法(obj原型链上的属性和方法不能被继承),后面的参数会当成obj的参数安装顺序传递进去。@H_502_1@
apply 函数@H_502_1@
apply和call的作用差不多,都可以用来继承,区别在与apply只有两个参数,第二个参数必须是数组或者arguments对象。否则会报TypeError错误。如果继承的对象obj有多个参数,则会吧argArray的参数依次对应obj的每个参数。@H_502_1@
总结@H_502_1@
502_1@
不同点在于call可以有多个参数,从第二个参数开始往后的参数会依次传给被继承的对象做参数。apply只有两个参数,第二个参数必须是数组类型或者arguments对象类型,而且他会把数组中的元素依次传递给被继承的对象做参数。@H_502_1@
通过以上几点,我们可以得到如果被继承的对象只有一个参数的可以使用call,如果被继承的对象有多个参数的,建议使用apply.@H_502_1@
补充@H_502_1@
js中可以实现多继承,只需要调用多次call或apply即可。如:@H_502_1@
如果构造函数this绑定了太多的属性(比如一些共用的函数),示例化后就会照成浪费(因为this里的属性和方法实例化后会复制一份给新对象,多个对象之间的属性和方法互不干涉,对于一些可以共用的方法来就会造成浪费)@H_502_1@
所以我们一般把共用的函数都放在原型链( 因此我们可以使用混合的而写法,使用原型链和( 让子的原型链指向父的示例(父的实例化对象)。如:@H_502_1@
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》及《用法总结》@H_502_1@
希望本文所述对大家JavaScript程序设计有所帮助。@H_502_1@语法
@H_502_1@
obj.call(thisObj,arg[,arg2[,arg3[,...agr]]]);
@H_502_1@
简介
@H_502_1@
示例
@H_502_1@
语法
@H_502_1@
obj.apply(this[,argArray]);
@H_502_1@
简介
@H_502_1@
示例
@H_502_1@
call
和apply
在功能是相同的。@H_502_1@
继承的优化
@H_502_1@
prototype
)上。但是使用call和apply无法继承原型链上的属性和方法。@H_502_1@
apply
或call
)组合的方式进行继承。@H_502_1@