DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> 有關JavaScript中call()和apply() 的一些理解
有關JavaScript中call()和apply() 的一些理解
編輯:JavaScript基礎知識     

call()方法和apply()方法,在上層應用中用的不是很多,但在底層寫JS框架的時候卻常常看到。然後度娘谷哥一番,也發現好多達人寫出了自己的理解和筆記,但始終還是雲裡霧裡,於是去W3C學習了下

在W3C網上研究這兩個方法的時候,看到一個詞語,叫“對象冒充”,這個概念本人覺得還是挺重要的,讓我對這兩個方法理解起來更加直觀。

call()方法,看下官方給出的例子

function sayColor(sPrefix,sSuffix) {
  alert(sPrefix + this.color + sSuffix);
};

var obj = new Object();
obj.color = "blue";

sayColor.call(obj, "The color is ", "a very nice color indeed.");

最後輸出的結果是“The color is blue, a very nice color indeed.”

call()方法就是將第一個參數替換方法中的this,然後後面的參數傳入該方法使用

apply()方法,同樣先看個官方給出的例子

function sayColor(sPrefix,sSuffix) {
  alert(sPrefix + this.color + sSuffix);
};

var obj = new Object();
obj.color = "blue";

sayColor.apply(obj, new Array("The color is ", "a very nice color indeed."));

最後輸出的結果仍然是“The color is blue, a very nice color indeed.”

其實call()方法和apply()方法可以粗略的認為是差不多的,第一個參數都是替換方法中this關鍵字,只是後面傳給方法的傳參方式不同,call是直接對應,apply是利用數組,在數組中一一對應

以上這篇有關JavaScript中call()和apply() 的一些理解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved