Function.prototype.apply()與Function.prototype.call()小結
來源:易賢網 閱讀:833 次 日期:2016-07-06 14:54:52
溫馨提示:易賢網小編為您整理了“Function.prototype.apply()與Function.prototype.call()小結”,方便廣大網友查閱!

JavaScript 中,某個函數的參數數量是不固定的,因此要說適用條件的話,當你的參數是明確知道數量時,用 call,而不確定的時候,用 apply,然后把參數 push 進數組傳遞進去。當參數數量不確定時,函數內部也可以通過 arguments 這個數組來便利所有的參數

老是忘掉這兩個東東的用下,寫下來做個記錄吧。

他們作用是一模一樣的,只是傳入的參數不一樣

apply

apply接受兩個參數,第一個制定了函數體內this對象的指向,第二個參數為一個帶下標的集合(可遍歷對象),apply方法把這個集合中的元素作為參數傳遞給被調用的函數:

var func = function(a, c, c){

  alert([a,b,c]); //[1,2,3]

}

func.apply(null, [1,2,3]);

call

call傳入的參數不固定,和apply相同的是,第一個參數也是代表函數體內的this指向,第二個參數開始往后,每個參數被依次傳入函數:

var func = function(a, b, c){

  alert([a,b,c]); //[1,2,3]

}

func.call(null, 1,2,3);

call是aplly的一顆語法糖。如果第一個參數為null,函數體內的this指向宿主對象,在瀏覽器中是window。

call和apply的用途

1.改變this指向

上面的例子就是啦

2.Function.prototype.bind

模擬Function.prototype.bind

Function.prototype.bind = function(context){

  var self = this;

  return function(){

    return self.apply(context, arguments);

  }

};

var obj = {

  name: 'cxs'

};

var func = function(){

  alert(this.name); //cxs

}.bind(obj);

fun();

更多信息請查看網絡編程
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
未满十八18勿进黄网站免费看