apply和call的用法总结

这两个东西不常用,但是有时却又特别的方便。我也是从别的地方找到的学习例子,自己再写一遍。

它们各自的定义:

apply:应用某一对象的一个方法,用另一个对象替换当前对象

 

call:调用一个对象的一个方法,以另一个对象替换当前对象。

 

var child="aa";

function demo(){

  var child="bb";

  console.log(this.child);

  console.log(this);

}

执行demo函数后,结果是(aa    window)

我们都知道输出一个变量时候,都会在当前的作用域里面找,找不到沿着作用域链向上层找,找到

最后还没有,就undefined了。

但是此处,多了个this,经验证this指向了window

定义一个对象 

var obj={

  child:"cc"

};

demo.call(obj);

此次的结果是( cc   obj),结论是函数demo的指向变成了obj,替换了window

Math.max(1,2,3)      Max.min(1,2,3) 获取最大和最小的值,但是参数只能是一串数字

Math.max.apply(null,arr);也可以获取数组中的最大值

null参数,被Math.max替换,用apply来arr的每一项作为参数传给Math.max()

操作数组的每一项map()

var nums=[1,2,3,5,6];
var result=nums.map(function(item,index,arr){
  return item*2
})
console.log(result);

//[2,4,5,10,12]

原文地址:https://www.cnblogs.com/gaoxt/p/7159298.html