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

你能够直接看例子,也能够先读一下介绍:app

call和apply是为了动态改变this而出现的,当一个object没有某个方法,可是其余的有,咱们能够借助call或apply用其它对象的方法来操做。dom

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

简单例子:this

callprototype

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() code

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通常使用状况ip

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

相关文章
相关标签/搜索