DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JS教程:call、apply、callee用法
JS教程:call、apply、callee用法
編輯:關於JavaScript     

可能不少學習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

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved