javascript中call、apply和bind

一、方法定义:

  • apply:调用一个对象的一个方法,用另一个对象替换当前对象。

例如:B.apply(A, arguments);即A对象应用B对象的方法。

  • call:调用一个对象的一个方法,用另一个对象替换当前对象。

例如:B.call(A, args1,args2);即A对象调用B对象的方法。

call 与 apply 的相同点:

  • 方法的含义是一样的,即方法功能是一样的;
  • 第一个参数的作用是一样的;

call 与 apply 的不同点: 两者传入的列表形式不一样

  • call可以传入多个参数;
  • apply只能传入两个参数,所以其第二个参数往往是作为数组形式传入

存在的意义:实现(多重)继承

二、例子
例1:

var name = '小张',
            age = 17;
        var obj = {
            name : '小刘',
            objAge : this.age,
            myFun : function(){
                console.log(this.name + "年龄" + this.age);
            }
        }
        console.log(obj.objAge);
        obj.myFun();

答案:
在这里插入图片描述
例2:

var fav = "盲僧";
        function shows(){
            console.log(this.fav);
        }
        shows();

答案:
在这里插入图片描述
比较一下这两者this的差别,第一个打印里面的this指向obj,第二个全局声明的shows()函数this是window。

1.call()、 apply()、 bind() 都是用来重定义this這个对象的!

例:

var name = '小张',
            age = 17;
        var obj = {
            name : '小刘',
            objAge : this.age,
            myFun : function(){
                console.log(this.name + "年龄" + this.age);
            }
        }
        var db = {
            name : '德玛',
            age : 99
        }
        obj.myFun();    //小刘年龄undefined  -->this 指向 对象 obj
        obj.myFun.call();   //小张年龄17 --> 此时 this 指向 window
        obj.myFun.call(db); //德玛年龄99 --> this 指向 对象 db
        obj.myFun.apply(db);    //德玛年龄99 --> this 指向 对象 db
        obj.myFun.bind(db)();   //德玛年龄99 --> bind 返回的是一个新函数,必须调用才会被执行

2.对比call、 bind、 apply 传参情况下

var name = '小张',
            age = 17;
        var obj = {
            name : '小刘',
            objAge : this.age,
            myFun : function(fm, t){
                console.log(this.name + "年龄" + this.age, '来自' + fm + '去往' + t);
            }
        }
        var db = {
            name : '德玛',
            age : 99
        }
        obj.myFun.call(db,'江西', '深圳');
        obj.myFun.apply(db, ['江西', '深圳']);
        obj.myFun.bind(db,'江西', '深圳')();
        obj.myFun.bind(db, ['江西', '深圳'])();

答案:
在这里插入图片描述
三者之间差距很小!

从上面的结果来看:

call、 bind、 apply 这三个函数的第一个参数都是this的指向对象,第二个参数差别就来了:

call 的参数是直接放进去的,第二第三第n个参数全都用逗号分隔,直接放到后面obj.myFun.call(db,‘江西’, …, ‘string’)。

apply的所有参数都必须放在一个数组里面传进去。

bind除了返回函数以外,它的参数和call 一样。

当然,三者的参数不限定是String 类型,允许是各种类型,包括函数,对象等等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值