Js 中apply 與 call

來源:互聯網
上載者:User

標籤:

最近看JS 總是遇到 對象的替換,不是很瞭解 JS中call 與apply的用法,在這裡 輕輕瞄一下,只是自己理解下其用法:

apply  定義:應用某一對象的一個方法,用另一個對象替換當前對象。 apply([thisObj[,argArray]])

call   定義:調用一個對象的一個方法,以另一個對象替換當前對象。 call([thisObj[,arg1[, arg2[,   [,.argN]]]]])

  從上面可以看出 其實他們的用法幾乎一樣,唯一的區別就是,調用時,apply傳入的參數形式是數組的形式,而call則沒有這個需求;也就是

當你的參數是明確知道數量時,用 call,而不確定的時候,用 apply,然後把參數 push 進數組傳遞進去;

具體的用法,用一個執行個體來看一下,如下:

 

function cat(){}cat.prototype={    food:"fish",    say: function(){        alert("I love "+this.food);    }}  var blackCat = new cat;  blackCat.say();  var dog={food:"bone"};  blackCat.say.call(dog);

 

 輸出的效果如所示:

 從上面就可以看出:

 以看出call和apply是為了動態改變this而出現的,當一個object沒有某個方法,但是其他的有,我們可以藉助call或apply用其它對象的方法來操作。

我們有一個對象dog= {food:"bone"},我們不想對它重新定義say方法,那麼我們可以通過call或apply用blackCat的say方法:blackCat.say.call(whiteDog);

有一種OOP中繼承的思想在裡面。

    以上只是在網上看到大神們的講解,比較容易理解的text,以此成文,在此和大家共勉,希望大家提供more 的理解。。。。。。

 

Js 中apply 與 call

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.