首先看下call方法
//call function show(){ alert(this.name+':'+this.age);
alert(this); } var p = {
name:'lemon',
age:'18'
}//通过call方法使show方法中的this指向p对象 show.call(p);
//show方法自调用,其实这种调用省略了window,所以this返回的内容就是window对象( window.show() = show() )
show();
再来看下apply方法,此方法与call方法很像,但是在传参的时候有所不同
function show(){
alert(this.name+':'+this.age);
alert(this);
}
var p = {
name:'lemon',
age:'18'
}//通过capply方法使show方法中的this指向p对象
show.apply(p);
//show方法自调用,其实这种调用省略了window,所以this返回的内容就是window对象( window.show() = show() )
show();
apply与call的不同
//call传参: show.call(this,'参数1',‘参数2’,'参数N')//像这样多少个参数就一直排下去 //apply传参: show.apply(this,['参数1','参数2','参数N'])//以数组的形式一直排!