92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线

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

2018-4-22    seo達人

如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

三種方法的作用

在 JavaScript 中

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

fruits.prototype = {
   color: 'red',
   say: function() { console.log('My color is ' + this.color); 
   }
} var apple = new fruits;
apple.say(); // 此時方法里面的this 指的是fruits // 結果: 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的指向已經同過call()方法改變了,指向的是banana,this.color就是banana.color='yellow'; // 結果是My color is yellow 

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

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

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

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

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

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

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

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

在 Javascript 中,多次 bind() 是無效的。更深層次的原因, bind() 的實現,相當于使用函數在內部包了一個 call / apply ,第二次 bind() 相當于再包住第一次 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

日歷

鏈接

個人資料

藍藍設計的小編 http://m.skdbbs.com

存檔

92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线
一本久久综合亚洲鲁鲁| 国产97色在线|日韩| 国产在线国偷精品产拍免费yy| 国产高清在线看| 国产精自产拍久久久久久蜜| 色综合中文字幕国产| 麻豆传媒在线观看| 日韩精品欧美一区二区三区| 91吃瓜网在线观看| 视频欧美一区| 国产精品亚洲美女av网站| 日本aa在线| 中文字幕欧美日韩在线| 欧美色中文字幕| 国产精品乱码久久久久久| 91综合免费在线| 亚洲二区精品| 国产剧情在线观看| 国产欧美一区二区三区视频| 最新91在线视频| 丝袜美腿亚洲色图| 亚洲国产一区二区三区a毛片| 国内偷自视频区视频综合| 亚洲国产成人在线播放| 韩国主播福利视频一区二区三区| 欧美精品18videos性欧美| 亚洲8888| 国产精选在线观看91| 欧美在线播放高清精品| 久久黄色美女电影| 一本色道久久88亚洲综合88| 欧美人狂配大交3d怪物一区| 天堂8中文在线最新版在线| 91在线小视频| 91精品啪aⅴ在线观看国产| 欧美色网一区二区| 久久久久中文| 亚洲精品视频在线| 国产精品拍天天在线| 国内成人自拍| 中日韩美女免费视频网站在线观看| 国产成人精品网址| 91福利在线免费观看| 在线āv视频| 欧美男同视频网| 国产精品丝袜黑色高跟| 亚洲视频电影在线| www.久久热.com| 亚洲丁香日韩| 日韩成人av电影在线| 国产一区二区三区不卡av| 色综合影院在线观看| 中文字幕日韩av电影| 中国人与牲禽动交精品| 欧美极品另类videosde| 日韩丝袜情趣美女图片| 国产黄色精品网站| 亚洲精品在线免费| 加勒比色老久久爱综合网| 日韩欧美三区| 国产日产欧美精品| 国产乱子轮精品视频| 精品中文av资源站在线观看| 日本久久久久久| 亚洲啪啪综合av一区二区三区| 在线观看国产精品网站| 国产一区在线精品| 无码国模国产在线观看| 国产在线看一区| 3atv在线一区二区三区| 制服丝袜日韩| 国产91精品对白在线播放| 日韩精品在线私人| 日本午夜精品一区二区三区| 婷婷六月综合网| 无码av中文一区二区三区桃花岛| 国产视频网站一区二区三区| 亚洲精品乱码久久久久久金桔影视| 91精品国产综合久久久久久久久久| 91麻豆精品国产综合久久久| 国产美女久久精品| 中日韩脚交footjobhd| 久久久国产精品一区二区中文| 九一久久久久久| 国产精品99久久免费观看| 色一情一乱一伦一区二区三区丨| 欧洲精品码一区二区三区免费看| 亚洲第一页自拍| 福利欧美精品在线| 亚洲一二三在线| 999久久久精品国产| 久久国产精品久久国产精品| jk漫画禁漫成人入口| 色综合天天综合网国产成人综合天| 久久国产精品久久久久久久久久| 国精产品一区一区三区四川| 国产精品伊人日日| 亚洲电影第1页| 久久久久国色av免费看影院| 日本三级视频在线观看| 午夜精品久久久久久久99黑人| 国产一区二区看久久| 日韩精品一区二区三区swag| 欧美久久久久| 亚洲一区日韩精品中文字幕| 成人日韩在线观看| 久久一级大片| 精品无人区太爽高潮在线播放| 亚洲欧美日韩在线播放| 尤物视频在线免费观看| 亚洲影院免费观看| 蜜臀国产一区| 欧美另类z0zxhd电影| 国产高清自拍视频在线观看| 日本三级视频在线播放| a级国产乱理论片在线观看99| 黑人巨大精品欧美一区免费视频| 精品乱码一区二区三区四区| 一区二区三区高清不卡| 亚洲成av人片在线观看www| 免费国产自线拍一欧美视频| 亚洲三级av| 麻豆av免费在线观看| 亚洲成人偷拍| 夜夜嗨av色综合久久久综合网| 国产大片一区| 91麻豆精品国产91久久久更新时间| 日韩亚洲欧美中文高清在线| 国产综合精品一区| 成人福利在线| 日韩欧美一区二区在线| 国内揄拍国内精品| 97久久精品人人爽人人爽蜜臀| 欧美日韩一区二区三区免费| 另类小说综合网| 大片免费在线看视频| 成a人片国产精品| 亚洲国产精品久久人人爱| 国产精品77777竹菊影视小说| 视频在线不卡免费观看| 日韩精品在线第一页| 777奇米四色成人影色区| 亚洲高清影院| 黄色av网站在线播放| 国模套图日韩精品一区二区| 密臀av在线播放| 精品国产欧美| 色呦呦一区二区三区| 久久女同互慰一区二区三区| 久久精品国语| 成人深夜福利app| 毛片一区二区| 亚洲国产成人91精品| 亚州国产精品久久久| 亚洲天堂偷拍| 日本一区二区三区在线观看| 久热爱精品视频线路一| 国产精品一区视频| 国产精品国产自产拍高清av水多| 97热精品视频官网| 日本精品一区| 国产精品一区二区三区网站| 白嫩亚洲一区二区三区| 精品高清美女精品国产区|