亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript中call,apply,bind的用法對比分析

2019-11-20 13:10:13
字體:
來源:轉載
供稿:網友

關于call,apply,bind這三個函數的用法,是學習javascript這門語言無法越過的知識點。下邊我就來好好總結一下它們三者各自的用法,及常見的應用場景。

首先看call這個函數,可以理解成"借用“,"請求"。想像一下如下的情景:你孤單一人漂泊在外,有急事想往家里打電話,可是很不巧,手機欠費了,或者沒電了,或者掉坑里了,總之你的手機就是用不成??墒悄惴谴蜻@個電話不可,于是你可以去借一下朋友的手機,或者借用一下鄰居的手機,或者公用電話,這樣呢,你就可以在自己沒有手機可用的情況下,完成打電話這個事情,而至于你是用誰的電話打的,就不重要了,反正和用你自己的手機打的電話是一樣的效果。call這個函數的初衷也和這個類似,下面我用代碼來模擬一下它的應用情景:

  var frog = {    name : 'frog',    say : function(){      alert(this.name);    }  }  var rabbit = {    name : 'rabbit'  }  frog.say.call(rubbit) // rabbit

rubbit這個對象是個啞吧,但是他想要說出自己的名字,光憑它自己的能力,是不可能實現的,好在呢,它有一個叫frog的好基友,它可以說話。于是呢,rubbit就請求frog替它實現這個心愿。frog.say.call()的第一個參數,一定是要填寫發出請求的人,律師喜歡稱為委托人。這里是rubbit請求frog替它say名字,所以填寫rubbit。這樣一來,在say的時候,就會查找rubbit的name,而不是frog的name了。如果這里填寫frog會是什么樣子呢?這就好比是自己請求自己做某事,喂自己代鹽也是可以的??梢栽囈幌拢?br />

 var frog = {    name : 'frog',    say : function(){      alert(this.name);    }  }  var rabbit = {    name : 'rabbit'  }  frog.say.call(frog) // frog

自己喂自己袋鹽,肯定是說自己的名字啦,這完全沒有什么意外的。下面我們來看看call的經典用法:

//把參數轉化成真正的數組對象function frog(){  var arr = [].slice.call(arguments);  console.log(arguments.slice,arr.slice)    // undefined function slice() { [native code] }}  frog(1,2,3,4)

能過這么一call,我們就可以把arguments對象當成數組對象來使用了。關于call的用法很多,翻開jquery的源碼,很容易就能找到很多運用的地方。在此不一一列舉了,還是回到我們前面的情景,借電話這種事太簡單了,打完電話,肯定還想捎點什么東西回去,畢竟這么多年漂泊在外,沒有好好孝敬下老人,買點當地的特產回去,肯定是極好的。可是外邊的生活壓力是如此之大,每天除了上班還要加班,如果請假的話,不但工資要扣,還要花費不少的路費,這些錢加起來,估計都夠老人在家里一年的用度了。想想不劃算,于是又想到call這個函數,請它幫忙,順道帶回去是非常明智的選擇,而且它不收費,不限量,不限重,有多少,帶多少。我再次用代碼來演示一下:

 var frog = {    name : 'frog',    send : function(money,food,milk,suagate){      alert(money+food+milk+suagate);    }  }  var rabbit = {    name : 'rabbit'  }  frog.send.call(rubbit,'money','food','milk','suagate')

如果你有錢任性,甚至可以把iphone6 plus什么的也寄幾個回去。.^_^.

說到這里call就差不多結束了,我也不知道上面的情景劇,是不是讓你明白了call是怎么回事,如果只是勾起了你的思鄉之情,那我表示抱歉。

call還有一個同父異母的兄弟,叫apply,如果弄明白了call的用法,那么apply其實也是一回事,唯一的區別呢,就是apply不喜歡傳東西的時候,一個東西打一個包,顯得很麻煩不說,還不環保。于是他就提供一個裝東西的大箱子,你把你要傳的東西全放在它提供的箱子里就好了。這個大箱子,就是一個數組。上面的例子,用apply來做的話,就是這樣子的:

var frog = {    name : 'frog',    send : function(money,food,milk,suagate){      alert(money+food+milk+suagate);    }  }  var rabbit = {    name : 'rabbit'  }                //注意參數的區別  frog.send.apply(rubbit,['money','food','milk','suagate'])

以上就是apply,call的前世今生了??墒侨f萬沒想到,apply和call的爸爸,前些年搞房地產發了財,在外邊還有一個叫bind 的私生子。雖然比call和apply這兩個哥哥晚出道幾年,但是能力也不容小視。只不過,他的身份,在某些地方,是不承認的。比如IE6。下面我還是用代碼來演示下他的本領:

  var name = 'rubbit';  var frog = {    name : 'frog',    say : function(){      setTimeout(function(money,milk){        alert(this.name+money+milk)      }.bind(this,'money','milk'),1000)    }  }  frog.say();

通過對比發現,bind可以直接連在function(){}后面用。相當于把call 和 apply 都省了,直接在函數后面指定委托人和要傳遞的參數。從傳參的風格上來說,更像call一些。

關于bind ,我們再來看一段經典的用法:

var obj = {  name : 'frog'}document.addEventListener('click',function(){  alert(this.name); // frog}.bind(obj),false);

總結一下,apply,call,bind,這三兄弟的相同點是:

 1. 第一個參數都是邦定作用域,即是在誰的地盤上做事。

 2. 都可以傳遞參數

不同點是:

  apply,call 兼容性更好,bind某些低版本的瀏覽器不支持。

  apply 傳遞的參數必須是用數組進行包裝的,而 call 和 bind 則是將要傳遞的參數一一列出。

大家是否對call,apply,bind三個函數的用法有了更深入的認識了呢,希望本文能對大家有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品一区二区在线| 国产精品激情av在线播放| 亚洲无亚洲人成网站77777| 亚洲免费伊人电影在线观看av| 国产成人短视频| 欧美日韩中文字幕在线视频| 国产精品视频精品视频| 亚洲最大福利网站| 成人字幕网zmw| 国产精品久久一区| 国产国产精品人在线视| 成人h片在线播放免费网站| 国产精品aaaa| 中文字幕国内精品| 538国产精品一区二区免费视频| 国产裸体写真av一区二区| 亚洲欧洲一区二区三区久久| 日韩在线观看高清| 亚洲国语精品自产拍在线观看| 欧美日韩国产在线看| 亚洲天堂色网站| 亚洲国产精品福利| 亚洲午夜激情免费视频| 91福利视频在线观看| 国产精品亚洲一区二区三区| 久久国产精品视频| 国产精品日日做人人爱| 精品久久久久久中文字幕| 国产免费一区二区三区在线能观看| 欧美精品久久久久久久| 日韩有码视频在线| 成人国产精品免费视频| 欧美最猛性xxxxx亚洲精品| 亚洲精品国产精品自产a区红杏吧| 91精品视频在线看| 亚洲午夜未删减在线观看| 亚洲色图欧美制服丝袜另类第一页| 欧美激情精品久久久久久免费印度| 国产精品亚洲综合天堂夜夜| 日日狠狠久久偷偷四色综合免费| 亚洲免费伊人电影在线观看av| 欧美激情a∨在线视频播放| 最近2019年中文视频免费在线观看| 久久久精品一区二区三区| 亚洲欧洲第一视频| 日韩欧美aaa| 欧美亚洲国产日韩2020| 久久久久久欧美| 日韩中文字幕精品视频| 国产日韩在线精品av| 国产日产欧美a一级在线| 欧美精品性视频| 久久精品99久久久久久久久| 亚洲天堂免费视频| 亚洲成色777777女色窝| 国产免费成人av| 中文字幕免费精品一区| 97视频在线播放| 国产精品久久久久久av福利| 亚洲欧洲日产国码av系列天堂| 国产精品色婷婷视频| 亚洲欧美另类国产| 亚洲欧美国产日韩中文字幕| 亚洲精品一区中文| 成人黄色网免费| 日韩av成人在线| 欧美伊久线香蕉线新在线| 69av在线视频| 亚洲视频第一页| 亚洲视频在线视频| 欧美精品在线第一页| 91久久国产精品91久久性色| 亚洲欧美日本另类| 91久热免费在线视频| zzijzzij亚洲日本成熟少妇| 欧美成人精品xxx| 久久久久日韩精品久久久男男| 日本高清久久天堂| 日韩美女中文字幕| 在线播放国产一区二区三区| 欧美丝袜一区二区| 国产精品老牛影院在线观看| 欧美日本亚洲视频| 精品久久久久久久中文字幕| 国产精品久久久久久久久男| 插插插亚洲综合网| 亚洲va欧美va国产综合久久| 色综合久久88色综合天天看泰| 97国产suv精品一区二区62| 久久久精品日本| 欧美最顶级的aⅴ艳星| 精品国偷自产在线| 欧美综合在线第二页| 亚洲精品美女久久| 亚洲 日韩 国产第一| 精品丝袜一区二区三区| 欧美日韩一区二区免费在线观看| 国产亚洲欧美视频| 亚洲男人第一网站| 亚洲女人被黑人巨大进入al| 日韩专区在线观看| 成人免费视频a| 亚洲人成伊人成综合网久久久| 久久99亚洲热视| 日韩精品极品毛片系列视频| 亚洲女成人图区| 国产一区二区三区视频| 欧美日韩亚洲精品内裤| 国产一区二区三区在线播放免费观看| 亚洲激情视频在线播放| 久久精品最新地址| 亚洲欧美日韩另类| 欧美视频国产精品| 91午夜在线播放| 亚洲精品欧美日韩| 久久好看免费视频| 欧美成人在线免费视频| 久久精品欧美视频| 粉嫩av一区二区三区免费野| 亚洲欧美激情视频| 亚洲在线www| 国产精品一二三在线| 国产精品久久久久久久电影| 国产精品美乳一区二区免费| 欧美日韩国产色视频| 国产va免费精品高清在线| 97视频在线观看视频免费视频| 亚洲白虎美女被爆操| 久热在线中文字幕色999舞| 亚洲视频免费一区| 日韩大片免费观看视频播放| 欧美午夜丰满在线18影院| 久久久999国产精品| 久久影院在线观看| 高清欧美性猛交xxxx| 午夜精品在线观看| 亚洲欧美日韩中文视频| 欧美激情一区二区三区在线视频观看| 国产精品日韩专区| 国产精品久久77777| 国产精品永久免费观看| 综合欧美国产视频二区| 欧美日韩国产在线播放| 亚洲第一视频网| 久久精品国产清自在天天线| 亚洲国产精品yw在线观看| xxx欧美精品| 国产精品久久婷婷六月丁香| 中日韩午夜理伦电影免费| 亚洲在线观看视频| 国产精品美女免费| 欧美理论电影网| 亚洲片在线资源| 久久精品国产免费观看| 国产日韩中文字幕在线| 亚洲成人教育av| 亚洲国产成人一区| 日韩欧美精品中文字幕| 欧美日韩国产一区二区三区| 国产精品一区二区性色av| 性欧美亚洲xxxx乳在线观看| 亚洲视频一区二区三区| 欧美乱大交xxxxx另类电影| 成人综合国产精品|