apply, call , bind

Posted liuxiaozai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了apply, call , bind相关的知识,希望对你有一定的参考价值。

apply, call , bind
3个都是改变函数内部的this指向(改变函数运行时上下文而存在),它们三个第一个参数都是 this
apply 与 call 区别
1. 虽然它们2个第一个参数都是this,但是apply第二个参数是一个数组的 ,而 call 第二个元素开始是数组里面的元素, 但是会立即执行 (列如)
1. const numbers = [5,481,56,89];
let maxInNumber = Math.max.apply( this, numbers );
let maxInNumber = Math.max.call( this, 5,484,56,89);
bind
它第二参数是接受的参数 列表, 不会去立即执行,返回一个改变上下文this函数的使用 , 原函数的this并没有改变 , 依旧指向全局的window

但是在箭头函数的情况下 apply , call 会失效
原因 1. 箭头函数不可以被当作构造函数, 不可以使用new 这个命令 , 不然会抛出异常
2. 箭头函数不可以使用arguments对象, 这个对象在函数体内是不存在的,如果想要使用Rest参数代替
3. 箭头函数不可以用作Generator函数 , 不可以使用yield命令
4. 箭头函数体内this对象就是定义时的对象 , 而不是使用的时候的对象















以上是关于apply, call , bind的主要内容,如果未能解决你的问题,请参考以下文章

javascript 面向对象学习——this,bindapply 和 call共同及入门技巧

JS中 call和apply的区别和作用

Javascript中call和apply的区别与详解

js中call和apply的区别

在JS中,call()方法和apply()方法到底该怎么应用?

Javascript 方法apply和call的差别