JS 的 apply 方法
1. 前言
apply() 的作用有两个: 1. 改变 this 指向 2. 将数组入参变为一般入参
刚开始看到 apply() 时,对它的用法非常模糊,而且不易理解,通过查找相关文章,才慢慢的明白它的妙用
2. 改变 this 指向
相信在网上查找 apply() 用法时,都会看到下面这段代码,首次运行,看到输出的结果,我是懵逼的
var person = {
fullName: function () {
return this.firstName + " " + this.lastName;
}
}
var person1 = {
firstName: "Bill",
lastName: "Gates",
}
const res = person.fullName.apply(person1)
console.log(res); // Bill Gates
如何理解 apply() 这段代码 ?
person.fullName() 调用 this.firstName 和 this.lastName 这两个属性,this 指向 person,但它没有这两个属性
使用 apply() 方法可以改变 this 的指向,将 this 的指向改为 person1,所以 person.fullName() 方法就可以成功访问到 this.firstName 和 this.lastName 这两个属性的值了
person.fullName.apply(person1)
可以理解为下面代码,但不要这么写,本质不一样
person1.fullName = person.fullName
person1.fullName()
3. 将数组入参变为一般入参
以 Math.max()
举例
// 正确用法
Math.max(1, 2, 3)
// 错误用法
Math.max([1, 2, 3])
使用 apply() 的第二个参数将数组入参变为一般入参
注意,这里的第一个参数值为 null,也就是没有改变 this 的指向
Math.max.apply(null, [1, 2, 3])
本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!
从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!
本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。
本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。
若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。