美文网首页
关于this指针-理解call、apply、bind

关于this指针-理解call、apply、bind

作者: Leson17 | 来源:发表于2020-07-20 02:30 被阅读0次

    首先,this指针只存在于函数(function)中。用于指向一个对象

    this在不同函数中有3种代表方式:

    普通函数中:代表window对象

    构造函数中:代表new出来的对象

    对象方法中:代表调用该方法的对象


    在这里插入图片描述

    改变对象this指向的3个方法:


    在这里插入图片描述

    call:改变函数this指向
    不传/null/undefined时,this都表示window


    在这里插入图片描述

    传对象,this代表该对象


    在这里插入图片描述

    传函数,this代表该函数


    在这里插入图片描述

    说明:除了,不传/null/undefined,代表window。其他的传什么,就代表什么。

    call:可以让b函数调用a的属性和方法。
    让this代表a。可传2参。


    在这里插入图片描述

    apply:将数组元素分别付给函数的参数
    传个数组,分别赋给x,y,z:call就不分别了。


    在这里插入图片描述

    bind:绑定事件期间改变this指向
    F的this指向obj,this.a就代表obj.a=1,点击网页时,执行F函数


    在这里插入图片描述

    call实现继承:
    A是构造函数,B使用call,就可以继承于A。
    使B对象可以使用A的属性和方法。


    在这里插入图片描述

    call实现移花接木:数组方法用到类数组中
    arguments是类数组
    test函数获得所有传参后,在call回调中进行处理


    在这里插入图片描述

    apply 取数组最大值
    除此之外,对于apply 而言,我们上面提到了它独有的一个特性,即apply 接收的是数组,在传递给调用函数的时候是以参数列表传递的。这个特性让apply 看起来比call 略胜一筹,比如有这样一个场景:给定一个数组[1,3,4,7],然后求数组中的最大元素,而我们知道,数组中并没有获取最大值的方法,一般情况下,你需要通过编写代码来实现。而我们知道,Math 对象中有一个获取最大值的方法,即Math.max(), max方法需要传递一个参数列表,然后返回这些参数中的最大值。而apply 不仅可以将Math 对象的max 方法应用到其他对象上,还可以将一个数组转化为参数列表传递给max,看代码就能一目了然:


    在这里插入图片描述

    以上便是 call 和 apply 比较经典的几个应用场景,熟练掌握这些技巧,并把这些特性应用到你的实际项目中,会使你的代码看起来更加耐人寻味!

    相关文章

      网友评论

          本文标题:关于this指针-理解call、apply、bind

          本文链接:https://www.haomeiwen.com/subject/duhjkktx.html