改变this的指向学习记录

  1.call方法

     

  // call方法调用函数,并且改变this的值this由windows改成了ifan

        const ifan = {

            age: 18

        }

        function kunkun() {

            console.log(this);

        }

        kunkun.call(ifan)

        //   this由windows改成了ifan

       2.apply方法

       

// 语法:fun.apply(thiaArg,[argsArray]) 跟的参数必须是数组

        const ifeng = {

            hoppy: 'pc'

        }

        function kunkun(x, y) {

            console.log(this);

            console.log(x + y);

        }

        kunkun.apply(ifeng, [1, 2])

        // 因为本身就是再调用函数,所以返回值就是函数的返回值

        // 3.bind方法,bind方法不会调用函数,但是可以改变this指向

     

   // 语法:fun.bind(thisArg,arg1,arg2)
        const ikun = {

            age: 18

        }

        function kunkun() {

            console.log(this);

        }

        kunkun.bind(ikun)

        // 这里我们发现控制台没有打印this,

        //     虽然我们调用了这个函数, 因为bind方法不会调用函数,

        //     但是可以改变this指向,

        //     此时的this已经指向了ikun这个对象了, bind方法返回值是个函数

        const fun = kunkun.bind(ikun)

        fun()

     //   这时我们调用这个fun函数,发现打印了这个this this指向了ikun

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值