首页 > 语言 > JavaScript > 正文

JS中call和apply函数用法实例分析

2024-05-06 15:33:17
字体:
来源:转载
供稿:网友

本文实例讲述了JS中call和apply函数用法。分享给大家供大家参考,具体如下:

call 函数

语法

obj.call(thisObj,arg[,arg2[,arg3[,...agr]]]);

简介

thisObj继承obj的属性和方法(obj原型链上的属性和方法不能被继承),后面的参数会当成obj的参数安装顺序传递进去。

示例

function animal(type,nickname){    this.type = type;    this.nickname = nickname;    this.sayHello = function(){      return 'hello';    }}function cat(name,type,nickname){    this.name = name;    //cat继承animal    animal.call(this,type,nickname);}console.log(new cat('wsscat','cut','tom'));/*cat { name: 'wsscat', type: 'cut', nickname: 'tom', sayHello: [Function] }*/

apply 函数

语法

obj.apply(this[,argArray]);

简介

apply和call的作用差不多,都可以用来继承,区别在与apply只有两个参数,第二个参数必须是数组或者arguments对象。否则会报TypeError错误。如果继承的对象obj有多个参数,则会吧argArray的参数依次对应obj的每个参数。

示例

function animal(type,nickname){    this.type = type;    this.nickname = nickname;    this.syaHello = function(){      return 'hello';    }}function cat(name,type,nickname){    this.name = name;    animal.apply(this,arguments);}console.log(new cat('wsscat','cut','tom'));/*cat { name: 'wsscat', type: 'wsscat', nickname: 'cut', syaHello: [Function] }*/

总结

callapply在功能是相同的。

相同点在于都是用于对象的继承,第一个参数都是thisObj.

不同点在于call可以有多个参数,从第二个参数开始往后的参数会依次传给被继承的对象做参数。apply只有两个参数,第二个参数必须是数组类型或者arguments对象类型,而且他会把数组中的元素依次传递给被继承的对象做参数。

通过以上几点,我们可以得到如果被继承的对象只有一个参数的可以使用call,如果被继承的对象有多个参数的,建议使用apply.

补充

js中可以实现多继承,只需要调用多次call或apply即可。如:

function animal(type,nickname){    this.type = type;    this.nickname = nickname;    this.syaHello = function(){      return 'hello';    }}function wscat(name,age){    this.name = name;    this.age = age;    this.sayMe = function(){      return 'my name:' + this.name + ', age:' + this.age;    }}function cat(name,age,type,nickname){    //第一种使用call    animal.call(this,type,nickname);    wscat.call(this,name,age);    //第二种使用apply    //animal.apply(this,[type,nickname]);    //wscat.apply(this,[name,age]);}console.log(new cat('wscat',2,'cat','tom');/*cat { type: 'cat', nickname: 'tom', syaHello: [Function], name: 'wscat', age: 2, sayMe: [Function] }*/            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选