call和apply

來源:互聯網
上載者:User

標籤:cat   console   lov   var   pre   new   des   需要   argument   

本文根據知乎中一些大佬的回複整理完成,如有更深見解,歡迎加入討論~~

在js OOP中,經常會這樣定義:

function cat(){}cat.prototype = {    food: ‘fish‘,    say: function(){        console.log(‘I love ‘ + this.food);    }        }var blackCat = new cat;blackCat.say(); //I love fish

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

function cat(){}cat.prototype = {    food: ‘fish‘,    say: function(){        console.log(‘I love ‘ + this.food);    }        }var blackCat = new cat;blackCat.say(); //I love fishvar whiteDog = {food: ‘bone‘};blackCat.say.call(whiteDog); //I love bone

call 和 apply 的區別是,call 需要把參數按順序傳遞進去,而 apply 是把參數放在數組中傳遞。

因此,js 中某個函數的參數數量是不固定的,可以使用 apply,將參數 push 進數組進行傳遞,也可以使用 arguments 對象來進行遍曆擷取所有參數;在參數明確知道,數目確定的時候可以使用 call.

舉個例子:

通過document.getElementsByTagName 選擇的 dom-節點是一種類似於array的對象,但是它不能應用Array 下的 push , pop等方法,我們可以通過:

var domNodes = Array.prototype.slice.call(document.getElementsByTagName(‘*‘));

這樣domNodes 就可以使用Array 下所有的方法了。

call和apply

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.