国产黄色免费网站_久久天天做天天爱综合色_精品国产一区久久久_成人黄色激情网站_久久成人在线视频_美女一区二区在线观看_亚洲精品免费一区亚洲精品免费精品一区 _91精品国产综合久久精品麻豆

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

2018-4-22    seo達人

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

三種方法的作用

在 JavaScript 中

  1. callapply 和 bind 是 Function 對象自帶的三個方法,都是為了改變函數(shù)體內部 this 的指向。
  2. callapply 和 bind 三者第一個參數(shù)都是 this 要指向的對象,也就是想指定的上下文
  3. callapply 和 bind 三者都可以利用后續(xù)參數(shù)傳參。
  4. bind 是返回對應 函數(shù),便于稍后調用;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 的區(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 當成一個數(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ù),當調用這個綁定函數(shù)時,綁定函數(shù)會以創(chuàng)建它時傳入 bind() 方法的第一個參數(shù) 作為 this,傳入 bind() 方法的 第二個以及以后的參數(shù)加上綁定函數(shù)運行時本身的參數(shù)按照順序作為原函數(shù)的參數(shù)來調用原函數(shù)。

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

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

在 Javascript 中,多次 bind() 是無效的。更深層次的原因, bind() 的實現(xiàn),相當于使用函數(shù)在內部包了一個 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://www.newchinaweekly.com

存檔

欧美国产成人精品| 一区二区三区在线视频播放| 日本国产在线| 九九视频免费观看| 麻豆av一区二区| 88国产精品欧美一区二区三区| 亚洲精品网址在线观看| 欧美日韩午夜影院| 亚洲日本在线a| 久久亚洲影视婷婷| 国产91在线看| 国产精品996| 欧美成人milf| 国产精品探花在线观看| 久久国产精品免费一区二区三区| 不卡av影片| 成人影院网站| 亚洲+变态+欧美+另类+精品| 中文字幕一区二区三区中文字幕 | 国产精品无码免费播放| 亚洲成人av影片| www.伊人久久| 老妇女50岁三级| 91人妻一区二区三区蜜臀| 黄色av片三级三级三级免费看| 国产精品91av| 亚洲黄色在线网站| aaaaa级少妇高潮大片免费看| 日本在线不卡一区二区| 稀缺呦国内精品呦| 亚洲久久久久久| 好吊一区二区三区视频| 9i精品福利一区二区三区| 国产精品9区| 九九热在线观看视频| xfplay资源站夜色先锋5566| 免费性色视频| 免费羞羞视频| 午夜亚洲成人| 一广人看www在线观看免费视频| 欧洲美女少妇精品| 欧美78videosex性欧美| 日本欧美日韩| 国内精品偷拍| 欧美丝袜丝交足nylons172| 国产精品成人av| 日韩国产欧美在线视频| 成人av在线播放网址| 国产精品毛片久久久久久| 午夜视频一区二区| 欧美一级艳片视频免费观看| 亚洲日韩欧美视频一区| 欧美激情视频在线观看| 国产免费成人av| 久久久99爱| 奇米精品一区二区三区| 无人码人妻一区二区三区免费| 欧美性xxxx图片| 国产黄色片网站| 欧美一级淫片a免费视频| 女色窝人体色77777| 美丽的姑娘在线观看免费动漫| 成年人视频免费在线播放| 国产精品色婷婷在线观看| 国产欧美日韩视频在线| 91亚洲国产成人精品一区二区三 | 台湾佬中文在线| 夜先锋av资源| 波多野结衣在线影院| 高清电影一区| 色无极亚洲影院| 精品一区二区三区在线播放 | 性视频1819p久久| 国产高清精品一区二区| 欧美激情亚洲天堂| 久久人妻少妇嫩草av蜜桃| jizz国产视频| 在线观看av的网站| 亚洲精品v亚洲精品v日韩精品| 欧美丰满日韩| 亚洲中国最大av网站| 亚洲毛片在线观看| 亚洲影院色无极综合| 久久美女福利视频| 久久久久99精品成人| 国产精品一区二三区| 不卡亚洲精品| 国内精品美女在线观看| 久久精品网站免费观看| 日韩欧美一级二级三级久久久| 91黄色8090| 永久免费的av网站| 少妇久久久久久被弄高潮| 天天操天天碰| jizz性欧美2| 国产精品一区二区91| 亚洲老司机av| 欧美 日本 亚洲| 亚洲国产精品18久久久久久| 天天色天天草| 欧美伦理影院| 国产丝袜欧美中文另类| 日韩的一区二区| 国产精品视频免费一区| 中文字幕一区久久| 欧美性受xxx黑人xyx性爽| jizz在线播放| 日韩精品二区| 欧美日韩高清影院| 国产欧美韩国高清| 中文字幕第二区| 影音先锋日韩| 黄色毛片在线观看| 丝袜久久网站| 欧美性xxxxxxx| 97在线精品国自产拍中文| 丰满人妻一区二区三区大胸| 精品人妻无码一区二区 | 国产精品亚洲二区| 欧美主播一区二区三区美女| 91精品国产乱码久久久久久久久| 老司机午夜免费福利| 日日摸夜夜夜夜夜添| 在线免费三级电影网站| 日韩中文字幕一区二区三区| 国产一区二区三区在线看 | 亚洲人成电影网站色…| 艹b视频在线观看| 秋霞午夜剧场| 黑人一区二区三区四区五区| 精品调教chinesegay| 日韩av自拍偷拍| 0608新视觉| 亚洲制服av| 欧美巨大另类极品videosbest| 国产美女久久久| 国产对白videos麻豆高潮| 3d黄动漫网站| 亚洲制服av| 久久免费高清视频| 亚洲精品20p| 亚洲一卡2卡三卡4卡2021四卡| 男人天堂亚洲| 国产精品久久久久久久岛一牛影视| 美女视频久久黄| 久草热视频在线观看| 国内精品露脸在线视频播放| 国产精品久久久久av电视剧| 亚洲高清免费一级二级三级| 国产人妖伪娘一区91| 毛茸茸多毛bbb毛多视频| 中出在线观看| 精品999日本| 日韩一区二区视频| 欧美aaa在线观看| 91亚洲国产成人久久精品麻豆| www黄在线观看| 日本一区二区三区视频视频| 欧美一级成年大片在线观看| 成熟妇人a片免费看网站| 小草av在线播放| 久久亚洲精品小早川怜子| 久久免费视频1| 香蕉久久视频| 日韩一区二区三区精品视频第3页 日韩一区二区三区精品 | 国产一级黄色录像| 影视先锋av在线| 国内精品久久久久影院色| 久久激情视频免费观看| 红桃视频 国产| 四虎影视在线观看2413| 国产欧美日韩视频在线观看| 在线视频福利一区| 超碰在线观看99| 欧美日一区二区| 久久久久久香蕉网| 欧美老熟妇乱大交xxxxx| 成年人在线免费观看视频网站| 一区二区日韩欧美| 日韩av在线免费播放| 亚洲成人黄色av| 四虎影视在线观看2413| 国产精品理伦片| 国产男女免费视频| 欧美性bbb| 久久伊人影院| 国产香蕉精品视频一区二区三区| 午夜黄色福利视频| 狠狠久久伊人中文字幕| 午夜精品福利在线| 日本黄大片一区二区三区| yourporn在线观看中文站| 亚洲成人av一区二区三区| 国产福利在线免费| 欧洲在线视频| 欧美一卡2卡3卡4卡| 久久成人小视频| 国产福利视频在线观看| av综合在线播放| 国产美女精品在线观看|