函数对象的call和apply方法

本文介绍了JavaScript中函数对象的call()和apply()方法,它们用于改变函数执行时的上下文(this)。当调用这些方法时,可以指定一个对象作为this,并且call()接受分开的参数列表,而apply()则需将参数放在数组中传递。此外,总结了this的四种情况:函数调用、方法调用、构造函数调用以及call/apply调用时的this指向。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

call() 和 apply()

1、这两个方法都是函数对象的方法,需要通过函数对象调用
2、当对函数调用call()和apply()都会调用函数执行
3、在调用call()和apply()时,可以将一个对象指定为第一个参数 此时这个对象将会成为函数执行时的this
4、call()方法可以将实参在对象之后依次传递
5、apply()方法需要将实参封装到一个数组中统一传递

<script>
    function fun(a,b){
        //alert('我是fun函数');
       // alert(this);
        console.log(a,b);
    }
   // var obj={};
   // fun();
   // fun.call();
   // fun.apply();
   // fun.call(obj);//'我是fun函数'
   // fun();//window
   // fun.call(obj);//object
   // fun.apply(obj);//object
     var obj={
         name:'obj',
         sayName:function(){
             alert(this.name);
         }
     };
    var obj2={
        name:'obj2'
    };
    //obj.sayName();//obj
    //obj.sayName.apply(obj2);//obj2   //参数是谁this就是谁
    //fun.call(obj,2,3);  //2,3
    fun.apply(obj,[2,3]); //2,3

</script>

总结:this的情况
1、以函数形式调用时, this永远都是window
2、以方法的形式调用时 this是调用方法的对象
3、以构造函数的形式调用时,this是新创建的那个对象
4、使用call和apply调用时,this是指定的那个对象

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值