apply 和 call 和 bind

本文详细介绍了JavaScript中apply和bind方法的区别与用法。通过具体示例解释了如何使用apply来处理数组参数,并介绍了bind方法如何创建绑定函数,用于改变函数的this指向。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.定义和区别

  1. Function.apply(obj,args)方法能接收两个参数  
  2. obj:这个对象将代替Function类里this对象  
  3. args:这个是数组,它将作为参数传给Function(args-->arguments)  
  4.   
  5.          call:和apply的意思一样,只不过是参数列表不一样.  
  6.   
  7.  Function.call(obj,[param1[,param2[,…[,paramN]]]])  
  8. obj:这个对象将代替Function类里this对象  
  9. params:这个是一个参数列表  
2.用法

在目标函数只需要n个参数列表,而不接收一个数组的形式([param1[,param2[,…[,paramN]]]]),可以通过apply的方式巧妙地解决这个问题:

  1. a)Math.max 可以实现得到数组中最大的一项  
  2.   
  3. 因为Math.max 参数里面不支持Math.max([param1,param2]) 也就是数组  
  4.   
  5. 但是它支持Math.max(param1,param2,param3…),所以可以根据刚才apply的那个特点来解决 var max=Math.max.apply(null,array),这样轻易的可以得到一个数组中最大的一项  
  6.   
  7. (apply会将一个数组装换为一个参数接一个参数的传递给方法)  
  8.   
  9.          这块在调用的时候第一个参数给了一个null,这个是因为没有对象去调用这个方法,我只需要用这个方法帮我运算,得到返回的结果就行,.所以直接传递了一个null过去  
  10.   
  11. b)Math.min  可以实现得到数组中最小的一项  
  12.   
  13. 同样和 max是一个思想 var min=Math.min.apply(null,array);  
  14.   
  15. c)Array.prototype.push 可以实现两个数组合并  
  16.   
  17. 同样push方法没有提供push一个数组,但是它提供了push(param1,param,…paramN) 所以同样也可以通过apply来装换一下这个数组,即:  
  18.   
  19. vararr1=new Array("1","2","3");   
  20.  vararr2=new Array("4","5","6");   
  21. Array.prototype.push.apply(arr1,arr2);   
  22.   
  23. 也可以这样理解,arr1调用了push方法,参数是通过apply将数组装换为参数列表的集合.  

一般在目标函数只需要n个参数列表,而不接收一个数组的形式([param1[,param2[,…[,paramN]]]]),可以通过apply的方式巧妙地解决这个问题! 


bind:1.用一句话总结bind的用法:该方法创建一个新函数,称为绑定函数,绑定函数会以创建它时传入bind方法的第一个参数作为this,传入bind方法的第二个以及以后的参数加上绑定函数运行时本身的参数按照顺序作为原函数的参数来调用原函数。

2. fn.bind(obj) 一般可以写成这样 obj.fn 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值