2021-07-19

bind,apply,call三者的区别

  • 三者都可用于改变this的指向,都有两个参数,形如: bind(obj,arg[0],arg[1],arg[2]…),
    call(obj,argp[0]),arg[1],arg[2]…)//前两者第二个参数都是以参数列表的形式传入,而apply()方法的第二个参数是以数组的形式传入的,形如:apply(obj,[arr])

  • bind方法和call很相似,第一参数是this的指向,后面传入的也是一个参数列表(但是bind()参数列表可以分多次传入,call()则必须一次性传入所有参数),但是bind()改变this指向后不会立即执行,而是返回一个永久改变this指向的函数。

  • apply也接受两个参数,第一个参数是this的指向,第二个参数是函数接受的参数,以数组的形式传入,且当第一个参数为null、undefined的时候,默认指向window(在浏览器中),使用apply方法改变this指向后原函数会立即执行,且此方法只是临时改变this指向一次。

  • 注意setTimeout()或者其他定时器在使用时注意:
    var name="lucy"; let obj={ name:"martin", say:function () { console.log(this.name); } }; obj.say(); //martin,this指向obj对象 setTimeout(obj.say,0); //lucy,this指向window对象
    正常情况下 say 方法中的 this 是指向调用它的 obj 对象的,而定时器 setTimeout 中的 say 方法中的 this 是指向window对象的(在浏览器中),这是因为 say 方法在定时器中是作为回调函数来执行的,因此回到主栈执行时是在全局执行上下文的环境中执行的,但我们需要的是 say 方法中 this 指向obj对象,因此我们需要修改 this 的指向

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值