call 与 apply,bind 的使用思路

Posted bbb324

tags:

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

call 与 apply 的区别是 cal 只能一个一个的传递参数,apply 是可以通过数组来传递参数, bind 需要进行一次额外的声明,

 

call 实例

var arr = {num: 2};
function aa(val1, val2) {
    return this.num+val1+val2;
}
console.log(aa.call(arr, 2,3)); // functionname.call(obj, functionArguments)

apply 实例

var obj = {num: 2};
var obj2 = {num: 3};
function add(val1, val2, val3) {
  return this.num+val1+val2+val3;
}
var arr = [1,2,3];
console.log(add.apply(obj, arr));
console.log(add.apply(obj2, arr));

bind 实例

var obj = {num: 5};
function add(val1, val2, val3) {
      return this.num+val1+val2+val3;
    }
    var bound = add.bind(obj);
    console.log(bound(3,4,5));

  

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

js的call,apply,bind的使用与区别

js/javascript : apply,call,bind三者的使用与区别

call(),apply(),bind()与回调

JavaScript中的call()apply()与bind():

实现bind的全程思路

JavaScript学习--Item9 call(),apply(),bind()与回调