JS中的call()、apply()和bind()小結

函数的三种调用方式 : 全局函数 对象方法 构造函数
*共同点,this的执行时确定的无法修改

a.全局函数:this指向window
b.对象方法:this指向对象
c.构造函数:this指向new创建的对象

上下文调用模式:可以动态修改this的指向
三种语法异同点:
相同点: 作用都是动态修改this
不同点:传参方式不一样

call(): 函数名.call(修改后的this,arg1,arg2,arg3………………)
apply(): 函数名.apply(修改后的this,[arg1,arg2,arg3…………])
bind(): 函数名.bind(修改后的this)

                * 不会立即执行函数,而是返回修改this之后的新函数
                * 一般用于回掉函数(定时器)

1.call()

语法: 函数名.call(修改的this指向,arg1,arg2,arg3,………………)

 function f1(a,b){
             console.log(this);
             console.log(a+b);
         };
         f1();//this.window
         f1.call({name:'张三',age:18},10,20);

打印结果:
在这里插入图片描述

2.apply()

语法 : 函数名.apply(修改的this指向,[数组或伪数组])

function f2(a,b){
            console.log(this);
            console.log(a+b);
         };
         f2(10,20);//this.window
         f2.apply({age:88},[20,30]);//自动遍历数组或伪数组的每一个元素给函数的形参赋值

打印结果:
在这里插入图片描述

3.bind()

(1)语法 : 函数名.bind(修改的this指向,arg1,arg2,arg3,…)
bind() : 不会执行这个函数,而是会返回一个修改了this之后的新函数

 function f3(a,b){
             console.log(this);
             console.log(a+b);
         }
         var newF3 = f3.bind([1,2,3])
         newF3(10,10);//newF3是bind方法返回函数,所以this变成了bind方法修改后的this指向

打印结果:
在这里插入图片描述
(2)结合定时器使用
a. 具名函数

var test = function(){
             console.log(this);  
         };

        //  var newTest = test.bind([1,2,3]);
        // setTimeout(newTest,2000);
        setTimeout(test.bind([1,2,3]),2000);

打印结果:
在这里插入图片描述

b. 匿名函数

setTimeout(function(){
            console.log(this);
            
        }.bind([10,20,30]),3000);

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值