亚洲av午夜福利精品一区人妖,亚洲乱码日产精品a级毛片久久,91精品视频观看,青草青草久热精品视频在线观看

JavaScript 中的 call()、apply()、bind() 的詳解

2018-4-22    seo達人

如果您想訂閱本博客內(nèi)容,每天自動發(fā)到您的郵箱中, 請點這里

三種方法的作用

在 JavaScript 中

  1. call、apply 和 bind 是 Function 對象自帶的三個方法,都是為了改變函數(shù)體內(nèi)部 this 的指向。
  2. call、apply 和 bind 三者第一個參數(shù)都是 this 要指向的對象,也就是想指定的上下文。
  3. callapply 和 bind 三者都可以利用后續(xù)參數(shù)傳參。
  4. bind 是返回對應(yīng) 函數(shù),便于稍后調(diào)用;apply 、call 則是立即調(diào)用 。
舉個栗子
function fruits() {}

fruits.prototype = {
   color: 'red',
   say: function() { console.log('My color is ' + this.color); 
   }
} var apple = new fruits;
apple.say(); // 此時方法里面的this 指的是fruits // 結(jié)果: My color is red
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

如果我們有一個對象 banana= {color : 'yellow'} ,我們不想重新定義 say 方法,那么我們可以通過 call 或 apply 用 apple 的 say 方法:

var banana = { color: 'yellow' };
apple.say.call(banana); // 此時的this的指向已經(jīng)同過call()方法改變了,指向的是banana,this.color就是banana.color='yellow'; // 結(jié)果是My color is yellow 

apple.say.apply(banana); // 同理,此時的this的指向已經(jīng)同過apply()方法改變了,指向的是banana,this.color就是banana.color ='yellow'; // 結(jié)果是My color is yellow

apple.say.apply(null); // nullwindow下的,此時,this 就指向了window ,但是window下并沒有clolr這個屬性,因此this.clolr就是window.color=undefined; // 結(jié)果是My color is undefined
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
call 和 apply 的區(qū)別

二者的作用完全一樣,知識接受 參數(shù) 的方式不太一樣。

call 是把參數(shù)按順序傳遞進去,而 apply 則是把參數(shù)放在 數(shù)組 里面。

var array1 = [12,'foo',{name:'Joe'},-2458]; var array2 = ['Doe' , 555 , 100]; Array.prototype.push.call(array1, array2); // 這里用 call 第二個參數(shù)不會把 array2 當(dāng)成一個數(shù)組,而是一個元素 // 等價于 array1.push("'Doe' , 555 , 100"); // array1.length=5; Array.prototype.push.apply(array1, array2); // 這里用 apply 第二個參數(shù)是一個數(shù)組 // 等價于:  array1.push('Doe' , 555 , 100); // array1.length=7;
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
類(偽)數(shù)組使用數(shù)組方法
var divElements = document.getElementsByTagName('div'); // 雖然 divElements 有 length 屬性,但是他是一個偽數(shù)組,不能使用數(shù)組里面的方法 Array.isArray(divElements);// false var domNodes = Array.prototype.slice.call(document.getElementsByTagName('div')); // 將數(shù)組對象 Array 里的 this 指向偽數(shù)組 document.getElementsByTagName('div'),  // slice() 方法可從已有的數(shù)組中返回選定的元素,不傳參數(shù)是,返回整個數(shù)組  Array.isArray(domNodes);// true
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
驗證一個對象的類型可以用
Object.prototype.toString.call(obj)
    
  • 1
bind() 方法

bind() 方法會創(chuàng)建一個 新函數(shù),稱為綁定函數(shù),當(dāng)調(diào)用這個綁定函數(shù)時,綁定函數(shù)會以創(chuàng)建它時傳入 bind() 方法的第一個參數(shù) 作為 this,傳入 bind() 方法的 第二個以及以后的參數(shù)加上綁定函數(shù)運行時本身的參數(shù)按照順序作為原函數(shù)的參數(shù)來調(diào)用原函數(shù)。

注意bind()方法創(chuàng)建的函數(shù)不會立即調(diào)用,在下面的例子中,最后 func() 才調(diào)用了函數(shù),這是它與 callapply的區(qū)別。

var bar = function(){ console.log(this.x);
} var foo = {
    x:3 }
bar(); // undefined var func = bar.bind(foo); //此時this已經(jīng)指向了foo,但是用bind()方法并不會立即執(zhí)行,而是創(chuàng)建一個新函數(shù),如果要直接調(diào)用的話 可以bar.bind(foo)() func(); // 3
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

在 Javascript 中,多次 bind() 是無效的。更深層次的原因, bind() 的實現(xiàn),相當(dāng)于使用函數(shù)在內(nèi)部包了一個 call / apply ,第二次 bind() 相當(dāng)于再包住第一次 bind() ,故第二次以后的 bind 是無法生效的。

var bar = function(){ console.log(this.x);
} var foo = {
  x:3 } var sed = {
  x:4 } var func = bar.bind(foo).bind(sed);
func(); //3 var fiv = {
  x:5 } var func = bar.bind(foo).bind(sed).bind(fiv);
func(); //3

日歷

鏈接

個人資料

藍藍設(shè)計的小編 http://m.skdbbs.com

存檔

亚洲av午夜福利精品一区人妖,亚洲乱码日产精品a级毛片久久,91精品视频观看,青草青草久热精品视频在线观看
<strike id="cy2gs"><menu id="cy2gs"></menu></strike>
  • <del id="cy2gs"><dfn id="cy2gs"></dfn></del>
  • 激情成人综合| 亚洲经典视频在线观看| 久久一区中文字幕| 性8sex亚洲区入口| 亚洲天堂激情| 久久人人精品| 国产午夜精品理论片a级大结局| 欧美韩日视频| 久久性色av| 欧美在线三级| 久久精品亚洲国产奇米99| 亚洲欧美国产77777| 亚洲一区二区三区欧美| 午夜精品视频在线| 午夜精品美女久久久久av福利| 亚洲在线1234| 欧美一区亚洲二区| 欧美中文字幕视频| 久久激情五月婷婷| 麻豆91精品| 久久婷婷丁香| 免费黄网站欧美| 欧美日韩国产成人在线| 欧美日韩一区二区免费在线观看| 欧美福利视频一区| 欧美午夜激情视频| 国产精品入口尤物| 国产性猛交xxxx免费看久久| 极品尤物一区二区三区| 影音先锋久久| 91久久综合亚洲鲁鲁五月天| 在线观看久久av| 亚洲激情成人| 一本大道久久a久久精品综合| 亚洲欧美国产制服动漫| 欧美一区二区三区视频免费播放 | 男女精品网站| 乱人伦精品视频在线观看| 欧美日韩91| 国产精品人人爽人人做我的可爱| 国产一区二区精品久久| 亚洲精品中文字幕女同| 欧美阿v一级看视频| 久久国产精品久久精品国产| 欧美一级淫片aaaaaaa视频| 狼人天天伊人久久| 欧美国产欧美亚洲国产日韩mv天天看完整 | 亚洲视频一区在线| 午夜视频一区在线观看| 久久久蜜臀国产一区二区| 欧美人成网站| 国产欧美日韩综合| 亚洲国产精品va| 亚洲美女视频在线观看| 亚洲你懂的在线视频| 久久精品人人做人人爽| 久色婷婷小香蕉久久| 国产精品xxx在线观看www| 国产真实久久| 99精品99久久久久久宅男| 久久精品国产91精品亚洲| 欧美jizz19hd性欧美| 欧美性色综合| 亚洲国产日韩欧美在线99| 一本色道久久综合亚洲91| 欧美伊人精品成人久久综合97| 欧美美女喷水视频| 国产亚洲激情| 亚洲精品久久久久中文字幕欢迎你| 午夜性色一区二区三区免费视频 | 99综合视频| 欧美在线亚洲| 欧美日韩成人综合| 伊人久久男人天堂| 中文欧美在线视频| 久久乐国产精品| 国产精品欧美在线| 亚洲欧洲精品一区二区三区| 亚洲欧美在线免费观看| 欧美日韩免费一区二区三区| 韩日精品中文字幕| 亚洲午夜一区二区| 欧美成人黑人xx视频免费观看| 怡红院精品视频| 一区二区三区高清在线| 久久夜色精品国产亚洲aⅴ| 国产精品午夜在线观看| 亚洲激情欧美| 久久er精品视频| 国产伦精品一区二区三区| 亚洲精品视频一区二区三区| 久久精品国产视频| 国产九九精品| 一区二区欧美日韩| 欧美超级免费视 在线| 影视先锋久久| 欧美一级播放| 欧美日韩亚洲一区二区三区在线观看 | 欧美理论大片| 一区在线观看| 欧美一区免费视频| 国产精品一区二区三区免费观看| 亚洲美女在线一区| 老司机免费视频一区二区| 欧美色综合天天久久综合精品| 亚洲国产精品久久久| 欧美一区二区三区播放老司机| 欧美日韩国产色综合一二三四 | 久久久久久国产精品mv| 欧美视频在线观看视频极品| 亚洲日本成人| 久久久久久久国产| 国产人成精品一区二区三| 午夜精品区一区二区三| 欧美午夜视频网站| 99精品国产在热久久| 欧美屁股在线| 最新国产乱人伦偷精品免费网站| 久久九九精品99国产精品| 国产日产欧产精品推荐色| 亚洲经典在线| 欧美专区亚洲专区| 国产一区二区三区不卡在线观看| 亚洲一区二区三区四区五区黄 | 亚洲精品护士| 久久久成人网| 国产主播一区二区三区四区| 香蕉久久夜色| 国产精品亚洲成人| 亚洲女ⅴideoshd黑人| 国产色综合网| 午夜亚洲视频| 红桃视频成人| 久久久噜噜噜久久人人看| 亚洲福利av| 欧美.com| 亚洲每日在线| 欧美日韩一区二区在线| 一区二区三区四区国产| 欧美视频一区在线观看| 亚洲综合视频1区| 国产欧美三级| 久久久久国产精品www | 久久中文字幕导航| 亚洲卡通欧美制服中文| 欧美日韩精品在线播放| 西西人体一区二区| 国产一区清纯| 久久九九精品99国产精品| 亚洲国产精品久久久| 欧美成人午夜| 亚洲一品av免费观看| 国产精品影片在线观看| 欧美自拍丝袜亚洲| 亚洲精品一区二区网址| 欧美色视频日本高清在线观看| 性欧美xxxx大乳国产app| 国产在线不卡视频| 久久久久久久97| 尤妮丝一区二区裸体视频| 欧美激情第一页xxx| 一区二区三区四区五区精品视频| 国产精品区一区二区三区| 久久精品一区二区三区不卡| 亚洲国产精品久久久久秋霞蜜臀 | 国产精品一级久久久| 久久午夜av| 亚洲精品系列| 国产伦精品一区二区三区视频孕妇| 欧美在线精品免播放器视频| 亚洲欧洲精品一区二区精品久久久| 国产精品人人爽人人做我的可爱| 鲁大师影院一区二区三区| 亚洲一区激情| 亚洲韩国日本中文字幕| 欧美日韩三级在线| 国产欧美一区二区三区久久人妖| 麻豆免费精品视频| 亚洲女性裸体视频| 亚洲人成亚洲人成在线观看| 国产欧美一区二区在线观看| 欧美人与性动交a欧美精品| 久久精品91久久香蕉加勒比| 一本色道久久综合亚洲精品不| 国内精品久久久久久影视8| 欧美视频一区二区三区| 麻豆精品视频在线观看视频| 亚洲免费影视第一页| 亚洲日本中文字幕| 国内精品嫩模av私拍在线观看| 欧美性片在线观看| 欧美精品七区| 久久久人人人| 亚洲欧美日本视频在线观看| 亚洲欧洲一区二区在线播放| 国产日韩在线一区| 欧美午夜欧美| 欧美另类99xxxxx| 另类亚洲自拍| 欧美影院一区|