apply:方法能劫持另外一个对象的方法,继承另外一个对象的属性.
Function.apply(obj,args)方法能接收两个参数
obj:这个对象将代替Function类里this对象
args:这个是数组,它将作为参数传给Function(args-->arguments)
apply 其实是将第二关数组参数转换为了参数列表,然后再传递给Function
call:和apply的意思一样,只不过是参数列表不一样.
Function.call(obj,[param1[,param2[,…[,paramN]]]])
obj:这个对象将代替Function类里this对象
params:这个是一个参数列表
示例:
function Person(name,age){
this.name=name;
this.age=age;
}
function Student(name,age,grade){
Person.apply(this,arguments); //call写法: Person.call(name,age,grade)
this.grade=grade;
}
var student=new Student("qian",21,"一年级");
student.name; //qian
student.age; //21
student.grade; //一年级
apply妙用
//求数组最小值
var min=Math.min.apply(null,array);
//求数组最大值
var max=Math.max.apply(null,array);
//可以实现两个数组合并,下例中改变的是arr1
var arr1 = [1,2,3]
var arr2 = [4,5,6]
[].push.apply(arr1,arr2) //或者Array.pprototype.push(arr1,arr2)
console.log(arr1) //[1,2,3,4,5,6]
通常在什么情况下,可以使用apply类似Math.min等之类的特殊用法:
一般在目标函数只需要n个参数列表,而不接收一个数组的形式([param1[,param2[,…[,paramN]]]]),可以通过apply的方式巧妙地解决这个问题。
Apply的第二个参数:数组或类数组
看一段代码:
var arr = Array.apply(null,{length:5});
// arr == [undefined,undefined,undefined,undefined,undefined]
上面代码解释:
{length: 5}是一个类数组对象,它类似于[undefined,undefined,undefined,undefined,undefined]
于是Array.apply(null, {length:5})就可以等效于:
Array.apply(null, [undefined, undefined, undefined, undefined, undefined])
或者Array(undefined, undefined, undefined, undefined, undefined)
或者new Array(undefined, undefined, undefined, undefined, undefined)