簡單使用.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

相關文章
相關標籤/搜索