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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值