面试题-关于bind、call、apply之间的区别

关于bind、call、apply之间的区别
我们知道bind、call、apply是ES5中改变this指向的,改变this执行这也是他们的共同点;以下面代码为实例来解释:

		function test(){
            console.log("在测试")
        }
        function exam(){
            // 通过call改变this指向
            test.call(this)
        }
        exam()  //"在测试"

		function test(){
            console.log("在测试")
        }
        function exam(){
            // 通过apply改变this指向
            test.apply(this)
        }
        exam()  //"在测试"


		function test(){
            console.log("在测试")
        }
        function exam(){
            // 通过bind改变this指向
            let a = test.bind(this)
            a()
        }
        exam()   //"在测试"

那么他们之前也存在着不同之处,同样,我们通过代码来进行解释说明:

		function a(male,str){
            console.log(male+"在测试"+str)
        }
        function b(male,str){
            // 通过call改变this指向,并传递参数
            // 这里的参数写在要指定的this对象后面,参数与参数之间,参数与改变的this对象之间使用逗号隔开
            //call是临时改变的,直接就是在调用函数本身
            a.call(this,male,str)
        }
        b("male",",非常认真") //male在测试,非常认真


		function a(male,str){
            console.log(male+"在测试"+str)
        }
        function b(male,str){
            // 通过apply改变this指向,并传递参数
            // 这里的参数写在要指定的this对象后面,参数与参数之间使用逗号隔开,参数要写在一个数组括号里面
            //apply是临时改变的,直接就是在调用函数本身
            a.apply(this,[male,str])
        }
        b("male",",非常认真") //male在测试,非常认真


		function a(male,str){
            console.log(male+"在测试"+str)
        }
        function b(male,str){
            // 通过bind改变this指向,并传递参数
            //bind是永久绑定的,如果下面的代码仍然需要用到这个地方的,可以找直接写q(male,str)
            //这里只是将对象与函数进行了一个绑定,返回了一个新的函数q
            let q = a.bind(this)
            //q执行
            q(male,str)
        }
        b("male",",非常认真") //male在测试,非常认真
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值