JS:apply、call、bind的区别

首先,它们是什么呢?我们先看call跟apply:

Function.prototype的方法有apply跟call,所以每个函数都包含call、apply属性。

共同点:都可以改变this的指向

差异:接收函数参数的方式不同

JS:apply、call、bind的区别

call: 第一个值是让t函数addEvent的this指向为obj对象,随后都是携带的addEvent函数的实参,需要逐个列出来

apply: 第一个值同上, 但是addEvent的实参通通都放在了一个数组中

那bind呢?它的作用也是改变this的指向,不过bind后还是函数,需要再进行调用;

JS:apply、call、bind的区别

===============================================

apply的妙用:

应用场景:

1、让 Math.max()方法可以挑出一个数组的最大值

JS:apply、call、bind的区别

2、合并两个数组(会改变原来的数组哦)

JS:apply、call、bind的区别

JS:apply、call、bind的区别

上一篇:call,apply,bind的用法及区别


下一篇:uni-app自定义app端的扫码界面