JavaScript call & apply 區(qū)別

網(wǎng)上就傳著一個等式來介紹這兩家伙:

foo.call(this, arg1,arg2,arg3) == foo.apply(this, arguments) == this.foo(arg1, arg2, arg3)

方法說明


call方法:

語法
call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) 
定義

調(diào)用一個對象的一個方法躲因,以另一個對象替換當(dāng)前對象。

說明

call 方法可以用來代替另一個對象調(diào)用一個方法搞监。call 方法可將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。 如果沒有提供 thisObj 參數(shù)腺逛,那么 Global 對象被用作 thisObj。

apply方法:

語法
apply([thisObj[,argArray]]) 
定義

應(yīng)用某一對象的一個方法棍矛,用另一個對象替換當(dāng)前對象。

說明

如果 argArray 不是一個有效的數(shù)組或者不是 arguments 對象够委,那么將導(dǎo)致一個 TypeError。 如果沒有提供 argArray 和 thisObj 任何一個參數(shù)茁帽,那么 Global 對象將被用作 thisObj屈嗤, 并且無法被傳遞任何參數(shù)潘拨。

實例理解


實例1

/* 定義一個animal類 */
function Animal() {
    this.name = "Animal";
    this.showName = function() {
        alert(this.name);
    }
}
/*定義一個Cat類*/
function Cat() {
    this.name = "Cat";
}
/*創(chuàng)建兩個類對象*/
var animal = new Animal();
var cat = new Cat();
//通過call或apply方法饶号,將原本屬于Animal對象的showName()方法交給當(dāng)前對象cat來使用了。
//輸入結(jié)果為"Cat"
animal.showName.call(cat);
//animal.showName.apply(cat,[]);

實例2

//創(chuàng)建一個A類
function A() {
    this.message = "message of a";
    this.getMessage = function() {
        return this.message;
    }
}

//創(chuàng)建一個A類實例對象
var a = new A();

//調(diào)用類實例getMessage方法獲得message值
alert(a.getMessage());

//創(chuàng)建一個B類
function B() {
    this.message = "message of b";
    this.setMessage = function(msg1, msg2) {
        this.message = msg1 + msg2;
    }
}
//創(chuàng)建一個B類實例對象
var b = new B();

//給對象a動態(tài)指派b的setMessage方法,注意,a本身是沒有這方法的!
b.setMessage.call(a, "a的消息", "琅束!");
// b.setMessage.apply(a, ["a的消息", "!"]);

//下面將顯示"a的消息"
alert(a.getMessage());
//給對象b動態(tài)指派a的getMessage方法,注意,b本身也是沒有這方法的!

實例3

function print(a, b, c, d) {
    alert(a + b + c + d);
}

function example(a, b, c, d) {
    //用call方式借用print,參數(shù)顯式打散傳遞
    print.call(this, a, b, c, d);
    //用apply方式借用print, 參數(shù)作為一個數(shù)組傳遞,
    //這里直接用JavaScript方法內(nèi)本身有的arguments數(shù)組
    print.apply(this, arguments);
    //或者封裝成數(shù)組
    print.apply(this, [a, b, c, d]);
}
//下面將顯示"九四安寧"
example("九", "四", "安", "寧");

實例4

function print(a, b, c, d) {
    alert(a + b + c + d);
}

//當(dāng)參數(shù)明確時可用call
//print.call(window, "九", "四", "安", "寧");

//foo參數(shù)可能為多個,當(dāng)參數(shù)不明確時可用apply給合arguments 
function foo() {
    print.apply(window, arguments);
}
foo("九", "四", "安", "寧");

以上無論是采用 animal.showName.call 還是 animal.showName.apply 方法涩禀,運行的結(jié)果都是輸出一個 Cat 的字符串然眼。說明 showName 方法的調(diào)用者被換成了 cat 對象,而不是最初定義它的 animal 了。這就是 callapply 方法的妙用丽声!

總結(jié)


  • 相同點

兩個方法產(chǎn)生的作用是完全一樣的

  • 不同點

方法傳遞的參數(shù)不同

Ps.參考鏈接:
http://www.iteye.com/topic/599108
http://www.jb51.net/article/28013.htm

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末雁社,一起剝皮案震驚了整個濱河市浴井,隨后出現(xiàn)的幾起案子霉撵,更是在濱河造成了極大的恐慌,老刑警劉巖徒坡,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異伦泥,居然都是意外死亡,警方通過查閱死者的電腦和手機不脯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門刻诊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來防楷,“玉大人则涯,你說我怎么就攤上這事∷谂校” “怎么了?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵档礁,是天一觀的道長。 經(jīng)常有香客問我事秀,道長野舶,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任平道,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘窘疮。我一直安慰自己,他們只是感情好闸衫,可當(dāng)我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蔚出,像睡著了一般。 火紅的嫁衣襯著肌膚如雪骄酗。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天睛琳,我揣著相機與錄音,去河邊找鬼师骗。 笑死,一個胖子當(dāng)著我的面吹牛丧凤,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播愿待,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼靴患,長吁一口氣:“原來是場噩夢啊……” “哼仍侥!你這毒婦竟也來了鸳君?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤或颊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后囱挑,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡游添,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了唆涝。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡廊酣,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出啰扛,到底是詐尸還是另有隱情,我是刑警寧澤隐解,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站煞茫,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏续徽。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一纫版、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧其弊,春花似錦、人聲如沸梭伐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至赂苗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間拌滋,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工鸠真, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吠卷。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓沦零,卻偏偏與公主長得像祭隔,于是被迫代替她去往敵國和親路操。 傳聞我的和親對象是個殘疾皇子疾渴,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容