可能不少學習javascript在使用call,apply,callee時會感到困惑,以下希望對於你有所幫助:
1、它是函數的方法或屬性;
2、它可以改變執行上下文的this指向;
3、作為另一個對象調用一個方法(即可以把一個對象的方法作為另一個對象的方法來引用);
4、apply方法類似,但只能接收數組為參數;
5、callee函數的調用者。
f.call(o,1,2) 等同於
o.m = f;
o.m(1,2);
例1:
function o1(value){
if(value < 100){
this.value = value;
}else{
this.value = 100;
}
}
function o2(value){
o1.call(this,value);
alert(this.value);
}
var o = new o2(133554) //100 改變了this的指向
例2:
function c1(){
this.m1 = function(){
alert(this.name);
}
}
function c2(){
this.name = “mike”;
}
var nc1 = new c1();
var nc2 = new c2(); //必須
nc1.m1.call(nc2); //mike 把方法m1作為對象nc2的方法來引用
例3:
function o1(arg){
if (arguments[1] < 100) {
this.value = arguments[1] ;
}
else {
this.value = 100;
}
}
function o2(arg){
o1.apply(this, arg);
alert(this.value);
}
var o = new o2([101,60]) //60 參數只能是數組
callee用法,常用於匿名函數中
var factorial = function(x){
if(x <= 1){
return 1;
}
return x * arguments.callee(x - 1);
}
alert(factorial(5)); //120