资讯专栏INFORMATION COLUMN

简单使用.call() 和 .apply()

jsyzchen / 642人阅读

摘要:你可以直接看例子,也可以先读一下介绍和是为了动态改变而出现的,当一个没有某个方法,但是其他的有,我们可以借助或用其它对象的方法来操作。它不能应用下的等方法。这一段来源知乎杨志

你可以直接看例子,也可以先读一下介绍:

call和apply是为了动态改变this而出现的,当一个object没有某个方法,但是其他的有,我们可以借助call或apply用其它对象的方法来操作。

call, apply都属于Function.prototype的一个方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,所以每个Function对象实例,也就是每个方法都有call, apply属性.既然作为方法的属性,那它们的使用就当然是针对方法的了.这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同.
从上面可以得出 call, apply 是给方法使用的,为了改变调用该方法的 this指针

简单例子:

call

function A() {
    this.getName = function (xx) {
        return xx;
    }
}

function B() {

}

var a = new A();
console.log( a.getName("i am A")  ); //i am A

var b = new B() ;
console.log( a.getName.call(b,"i am B") );  // i am B

B 函数中没有 任何方法 , A 函数有个 getName() 方法 ,a.getName() 自然成立 ,但 B 也要使用 getName() 的方法怎么办呢 ? 那就用 call(this,"参数") !!

可以 再理解一下这句话 -- 我们可以借助call或apply调用其它对象的方法来操作,call和apply是为了动态改变this而出现的 ,本来 a.getName() 的 this 指向 a, call 动态的 把 this 指向了 b ,变成了 b.getName()

apply
apply 与 call 只是参数的使用不同而已

function A() {
    this.sun = function (a ,b) {
        return a+b;
    }
}

function B() {

}

var a = new A();
console.log( a.sun(1,2)  ); //3

var b = new B() ;
console.log( a.sun.call(b,2,2) );  // 4

console.log( a.sun.apply(b,[3, 3]) );  //6

call和apply一般使用情况

用的比较多的,通过document.getElementsByTagName选择的dom 节点是一种类似array的array。它不能应用Array下的push,pop等方法。我们可以通过:
var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*"));
这样domNodes就可以应用Array下的所有方法了。 --这一段来源: 知乎-杨志

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/80418.html

相关文章

  • callapply bind的简单使用方法

    摘要:也就是说,区别就是,当你希望改变上下文环境之后并非立即执行,而是回调执行的时候,使用方法而则会立即执行函数。 - call、apply:在 javascript 中,call 和 apply 都是为了改变某个函数运行时的上下文(context)而存在的,换句话说,就是为了改变函数体内部 this 的指向。 JavaScript 的一大特点是,函数存在「定义时上下文」和「运行时上下文」以...

    Harriet666 评论0 收藏0
  • 可能遇到假的面试题:不用callapply方法模拟实现ES5的bind方法

    摘要:来自朋友去某信用卡管家的做的一道面试题,用原生模拟的方法,不准用和方法。他们的用途相同,都是在特定的作用域中调用函数。不同之处在于,方法传递给调用函数的参数是逐个列出的,而则是要写在数组中。 本文首发我的个人博客:前端小密圈,评论交流送1024邀请码,嘿嘿嘿?。 来自朋友去某信用卡管家的做的一道面试题,用原生JavaScript模拟ES5的bind方法,不准用call和bind方法。 ...

    李世赞 评论0 收藏0
  • 可能遇到假的面试题:不用callapply方法模拟实现ES5的bind方法

    摘要:来自朋友去某信用卡管家的做的一道面试题,用原生模拟的方法,不准用和方法。他们的用途相同,都是在特定的作用域中调用函数。不同之处在于,方法传递给调用函数的参数是逐个列出的,而则是要写在数组中。 本文首发我的个人博客:前端小密圈,评论交流送1024邀请码,嘿嘿嘿?。 来自朋友去某信用卡管家的做的一道面试题,用原生JavaScript模拟ES5的bind方法,不准用call和bind方法。 ...

    ConardLi 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<