关于 apply,call 和 bind 的理解

apply、call 和 bind 的理解

apply、call 和 bind 都可以改变当前函数 this 的指向。但是 apply 传的参数时一个数组,call 传的参数是一个序列。bind 是返回对应函数,便于稍后调用;apply 、call 则是立即调用 。

  • apply的使用  

    1. 基本使用,apply 将 Function 中的 this 指向了 newObj 这个对象,args 参数是传给 newObj 中的 Function 的参数,call 类似。

      Function.prototype.apply(newObj,[arg1,arg2,arg3])  
    2. 求一个数组的最大值,在非严格模式下,此时的 null(undefined)是JS执行环境的全局变量window,因为 Math.max( ) 不支持数组,所以此时用 apply 函数时,传入Math.max( ) 中的参数为数组中的值,而不是整个数组。

      Math.max.apply(null,[123])    
    3. 数组合并
      Array.prototype.push.apply(array1, array2)
  • call 的使用

    1. 基本使用

       Function.prototype.apply(newObj, arg1,arg2,arg3)  
    2. 类数组的用法,将类数组变为数组

       Array.prototype.slice.call(arguments)
       Array.prototype.slice.call(document.getElementsByTagName("*"))
  • bind 的使用

    1. 基本使用

       Function.prototype.bind(newObj)  
  • 补充
    call 的性能比 apply 好,因为 apply 的参数是一个数组,会多一次引用访问,而且需要将其遍历合并到arguments隐式参数数组上。

如果有什么不正确的地方,欢迎大家批评指正

参考文档
http://www.cnblogs.com/coco1s/p/4833199.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值