专栏名称: klivitamJ
android/前端工程师
目录
相关文章推荐
新闻广角  ·  马斯克:关闭美国之音 ·  昨天  
新闻广角  ·  多家车企官宣:接入DeepSeek ·  2 天前  
新闻广角  ·  王濛怒斥韩国选手推搡林孝埈 ·  2 天前  
新闻广角  ·  墨西哥客车与货车相撞起火!至少30人遇难 ·  2 天前  
新闻广角  ·  哪吒2进入全球票房TOP50 唯一非好莱坞影片 ·  2 天前  
51好读  ›  专栏  ›  klivitamJ

谈一谈我如何使用call、apply、bind

klivitamJ  · 掘金  ·  · 2019-05-17 03:12

正文

阅读 38

谈一谈我如何使用call、apply、bind

其实我接触前端时间并不长,很多都处于学习阶段。但是随着自己掌握知识越发复杂起来,我发现学习一门新技术并没有想象中的容易,甚至要比想象中难很多。虽然很多技术方面、思想都是触类旁通的。但是很多技术深处的差异性和基础让我学的东西越来越多。

这三个名词,如果你看源码看的比较多的话。你会看到很多地方用这个东西。但是并不太了解他们的关系。我们今天就是为了彻底搞懂这三个的区别。

bind和apply

首先来谈谈 call() apply() ,首先他们俩都是为了改变某个函数运行时的上下文而存在的。通俗点说就是改变this的指向的。

首先我们得明白两点:

  • call() apply() 是Function对象的方法,每个函数都能调用。
  • call()和apply()的第一个参数都是你要指定的执行上下文,剩下的部分就是你想要传递的参数,也就是传给调用call()和apply()方法的函数的参数。

来看下面一段代码:

function show(...arg){
	console.log(arg);
	console.log(this.name)
}
var person={
	name:"klivitam",
	age:24	
};
show.call(person,"男","爱好唱歌","宅男");

show.apply(person,["男","爱好唱歌","宅男"]);
复制代码

效果图如下:

由上面的例子我们可以清楚发现,call()和apply()函数的第一个参数都是改变this的指向,而call()和apply的区别仅仅只有call()需要一项一项的传,但是apply()直接传递一个数组就行了。

apply的用法

关于call()和apply()的用法呢?我也简单介绍几个(百度上面看的,自己也实现了一下,挺好用的,但是看zepto源码里面用apply()挺多的):

  • 数组之间追加
var array1=[1,3,5];
var array2=[54,"join"];
[].push.apply(array1,array2);
console.log(array1); // [1,3,5,54,join]
复制代码

这里可以理解成push方法没有提供push一个数组,但是它提供了push(param1,param,…paramN) 所以我们也可以通过apply来装拯救这个数组,因为apply会打散一个数组,一个个传进来。 也可以写成array1.push.apply(array1,array2);

  • 获取数组中的最大值和最小值
var  numbers = [1,13,-3];
var maxInNumbers = Math.max.apply(Math, numbers),   //13
maxInNumbers = Math.max.call(Math,1,13,-3); //13
复制代码

number 本身没有 max 方法,但是 Math 有,我们就可以借助 call 或者 apply 使用其方法。但是用apply记得是传入一个数组,apply()里面第一个参数可以是Math,也可以是null,这个是因为没有对象去调用这个方法,我只需要用这个方法帮我运算,得到返回的结果就行。

但是它支持Math.max(param1,param2,param3…),所以可以根据刚才apply的那个特点来解决 var maxInNumbers=Math.max.apply(null,numbers),这样轻易的可以得到一个数组中最大的一项(apply会将一个数组装换为一个参数接一个参数的传递给方法,记住)

  • 验证是否是数组(前提是toString()方法没有被重写过)
// isArray的源码
function






请到「今天看啥」查看全文