从入门到手写call和apply

本文详细解析了JavaScript中call和apply方法的作用,包括它们如何改变函数调用的this指向,通过实例演示了两者之间的区别,并手写了call和apply的实现。重点讲解了在传参方式上的差异,以及在严格模式下的行为。
摘要由CSDN通过智能技术生成

1.什么是call和apply?

对于js定义一个函数,如果不是对象的方法,那么它就是全局对象的函数。window对象身上的

例:


let obj = {
    name: 'test',
    getName: function() {return this.name}
}

//对象的方法
obj.getName();

funciton getName() { return 'aa'}
//window的方法
getName()

apply和call是一个方法 - 作用是改变函数调用的this指向

apply

let obj = {
    getName: function () {return this.name}
}

let obj2 = {
    name: 'zz'
}

//将obj的方法给obj2调用方法
obj.getName.apply(obj2) - 返回zz

call

let obj = {
    getName: function () {return this.name}
}

let obj2 = {
    name: 'zz'
}

//将obj的方法给obj2调用方法
obj.getName.call(obj2) - 返回zz

apply和call的区别

唯一的不同 - 方法接受的参数形式不用
call - 直接传参
apply- 数组形式传参

例如

let obj = {
    getName: function(name,age) {return name + '' + age}
}

let obj1 = {}

obj.getName.call(obj1, 'aa', '1')
obj.getName.apply(obj1, ['aa', '1'])

如果第一个参数传null

在 JavaScript 严格模式下,如果 apply() 方法的第一个参数不是对象,则它将成为被调用函数的所有者(对象)。在“非严格”模式下,它成为全局对象。

2.手写call和apply

手写call

Function.prototype.mycall = funciton(obj) {
    //是否传入对象,传入为当前对象否则为window
    var obj = obj || window 
    // 赋值当前函数给func
    obj.func = this 
    //将参数维数组转为真数组进行调用
    obj.func(...([...arguments].slice(1)))
    //还原对象,删除函数
    delete func
}

手写apply

Function.prototype.mycall = funciton(obj) {
    //是否传入对象,传入为当前对象否则为window
    var obj = obj || window 
    // 赋值当前函数给func
    obj.func = this 
    //将参数维数组转为真数组进行调用
    obj.func(...arguments[1])
    //还原对象,删除函数
    delete func
}

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值