call()和apply( )
- 这两个方法都是函数对象的方法,需要通过函数对象来调用。
- 当对函数调用call()和apply()都会调用函数执行
- 在调用call()和apply()方法时,可以将一个对象指定为第一个参数,此时这个对象将会成为函数执行时的this。
- call()方法可以将实参在对象之后依次传递
- apply()方法需要将实参封 装到一个数组中统一传递
function fun(a,b){
console.log(this.name);
console.log("a=" + a);
console.log("b=" + b);
}
var obj = {
name : '孙悟空',
sayName : function(){
console.log(this.name);
}
};
var obj2 = {
name : '猪八戒',
sayName : function(){
console.log(this.name);
}
};
obj.sayName.call(obj2);//猪八戒
fun.call(obj,1,2);//孙悟空 a=1 b=2
fun.apply(obj2,[1,2]);//猪八戒 a=1 b=2
arguments
在调用函数时,浏览器每次都会传递进两个隐含的参数,
- 函数的上下文对象 this
- 封装实参的对象 arguments
- arguments是一个类数组对象,它也可以通过索引来操作数据,也可以获取长度。
- 在调用函数时,我们所传递的实参都会在arguments中保存。
- arguments.length可以用来获取实参的长度。
- 即使不定义形参,也可以通过arguments来使用实参,只不过比较麻烦。
arguments[0]表示第一个实参;
arguments[1]表示第二个实参… - 它里边有一个属性叫做callee,这个属性对应一个函数对象,就是当前正在指向的函数的对象。
arguments.callee