js call(),apply(),对象冒充,改变变量作用域

1.apply();

function box(n1,n2){
    return n1+n2;
}
function pox(n1,n2){
    alert(box.apply(this,[n1,n2]));   //this指window下全局属性
                                      //这里没有返回值,没有运算,通过冒充box里的运算来执行
}
pox(10,20);        //30

注:如果参数过多,冒充对象传参的时候可以写成arguments

function box(n1,n2){
    return n1+n2;
}

function pox1(n1,n2){
    alert(box.apply(this,arguments));
}
pox1(10,30);    //得到40

2.call()

function box(n1,n2){
    return n1+n2;
}

//call和apply只是传参形式不同,其他都一样
function pox2(n1,n2){
    alert(box.call(this,n1,n2));
}
 pox2(20,0);    //20

3.call()和apply()最大的好处,就是对象不需要与方法发生任何关联.对象和方法不会有多余的关联操作,对程序的维护提供便利

原文地址:https://www.cnblogs.com/xiaoxinzi/p/8516287.html