关于apply与call

本文详细介绍了JavaScript中的apply与call方法,解释了它们如何用于劫持对象方法和继承属性,以及两者之间的区别。通过实例展示了参数传递的不同方式,并强调了根据参数顺序选择合适方法的重要性。
摘要由CSDN通过智能技术生成

1.apply与call的作用

——这两个方法都能劫持另外一个对象的方法,继承另外一个对象的属性。

2.apply与call的区别与用法

——

Function.apply(obj,args)
//apply方法有两个参数,第一个是对象,第二个是数组。

Function.call(obj,[param1[,param2[,…[,paramN]]]])
//与apply方法不同的是第二个开始的参数,这里是参数列表,而apply第二个参数是数组。

例子:
// apply
function People(name,age){
  this.name = name;
  this.age = age;
}
function Man(name,age,sex){
  People.apply(this,arguments);
  this.sex = "man";
}

//call
function People(age,name){
  this.name = name;
  this.age = age;
}
function Man(name,age,sex){
  People.call(this,age,name,sex);
  this.sex = "man";
}

注意,apply的例子中,由于man和people的前两个参数对应的顺序是一致的,所以这里使用apply。

call的例子中,由于people和man前两个参数顺序不同,所以这里使用call,call方法的this之后的参数是可以自己指定参数列表对应值的位置的。

转载于:https://www.cnblogs.com/SLEBEE/p/3962909.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值