call()和apply()

方法定義:
調(diào)用一個(gè)對(duì)象的一個(gè)方法,以另一個(gè)對(duì)象替換當(dāng)前對(duì)象。

  • 共同點(diǎn)
    都可以用來代替另一個(gè)對(duì)象調(diào)用一個(gè)方法,第一個(gè)參數(shù)都是用來執(zhí)行運(yùn)行環(huán)境,this 會(huì)被指定為當(dāng)前調(diào)用對(duì)象
    關(guān)于第一個(gè)參數(shù)供常,輸入類型不同,對(duì)應(yīng)的this也不一樣,如下:
    function a(){
        console.log(this);
    }
    a.call();//window
    a.call(null);//window
    a.call(undefined);//window
    a.call(1);//Number
    a.call('aaa');//String
    a.call(true);//Boolean
    a.call(a);//function(){}
    a.call({'a':'b'});//Object{}
  • 不同點(diǎn)
    call(),有多個(gè)參數(shù)
    apply()只有兩個(gè)參數(shù)鸡捐,第二個(gè)參數(shù)是一個(gè)數(shù)組

用法

  • 一個(gè)簡(jiǎn)單的例子:
    獲取數(shù)組中最大值和最小值,
    var num=[3,23,543,2,52,-1000];
    var maxNum=Math.max.apply(this,num);
    var minNum=Math.min.call(this,num[0],num[1],num[2],num[3],num[4],num[5]);

不確定有幾個(gè)參數(shù)的時(shí)候使用

    function n(){
        console.log.apply(this,arguments)
    }
    // n(1,3,'a','',{},true);

call()傳入 的第一個(gè)參數(shù)作為 this栈暇,傳入的第二個(gè)以及以后的參數(shù)加上綁定函數(shù)運(yùn)行時(shí)本身的參數(shù)按照順序作為原函數(shù)的參數(shù)來調(diào)用原函數(shù),看代碼進(jìn)行理解

    function eat(x,y) {
          console.log(x+y);
    }
    function drink(x,y) {
           console.log(x-y);
    }
    drink.call(eat,3,2);//1
    eat.call(drink,3,2);//5

擴(kuò)展bind()方法

參數(shù)用法類似于call,但call/apply 是立刻調(diào)用函數(shù)的箍镜,bind 是返回一個(gè)函數(shù)源祈,然后可以在其他時(shí)候調(diào)用。

this.x = 9; 
var module = {
  x: 81,
  getX: function() { return this.x; }
};

console.log(module.getX()); // 81

var retrieveX = module.getX;
console.log(retrieveX());//9, 因?yàn)?this 指向全局對(duì)象
var boundGetX = retrieveX.bind(module);
console.log(boundGetX()); // 81
  • 比較
var person = {  
  name: "James Smith",
  hello: function(thing) {
    console.log(this.name + " says hello " + thing);
  }
}
// call
person.hello.call(person, "world"); //James Smith says hello world

// bind
var helloFunc = person.hello.bind(person);
helloFunc("world");  //James Smith says hello world

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末色迂,一起剝皮案震驚了整個(gè)濱河市香缺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌歇僧,老刑警劉巖赫悄,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡埂淮,警方通過查閱死者的電腦和手機(jī)姑隅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來倔撞,“玉大人讲仰,你說我怎么就攤上這事』居” “怎么了鄙陡?”我有些...
    開封第一講書人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)躏啰。 經(jīng)常有香客問我趁矾,道長(zhǎng),這世上最難降的妖魔是什么给僵? 我笑而不...
    開封第一講書人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任毫捣,我火速辦了婚禮,結(jié)果婚禮上帝际,老公的妹妹穿的比我還像新娘蔓同。我一直安慰自己,他們只是感情好蹲诀,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開白布斑粱。 她就那樣靜靜地躺著,像睡著了一般脯爪。 火紅的嫁衣襯著肌膚如雪则北。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,146評(píng)論 1 297
  • 那天痕慢,我揣著相機(jī)與錄音咒锻,去河邊找鬼。 笑死守屉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蒿辙。 我是一名探鬼主播拇泛,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼思灌!你這毒婦竟也來了俺叭?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤泰偿,失蹤者是張志新(化名)和其女友劉穎熄守,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡裕照,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年攒发,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片晋南。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惠猿,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出负间,到底是詐尸還是另有隱情偶妖,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布政溃,位于F島的核電站趾访,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏董虱。R本人自食惡果不足惜扼鞋,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望空扎。 院中可真熱鬧藏鹊,春花似錦、人聲如沸转锈。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽撮慨。三九已至竿痰,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間砌溺,已是汗流浹背影涉。 一陣腳步聲響...
    開封第一講書人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留规伐,地道東北人蟹倾。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像猖闪,于是被迫代替她去往敵國(guó)和親鲜棠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

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