嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片

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

2018-4-22    seo達(dá)人

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

三種方法的作用

在 JavaScript 中

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

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

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

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

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

apple.say.apply(null); // nullwindow下的,此時(shí),this 就指向了window ,但是window下并沒有clolr這個(gè)屬性,因此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ù)按順序傳遞進(jìn)去,而 apply 則是把參數(shù)放在 數(shù)組 里面。

var array1 = [12,'foo',{name:'Joe'},-2458]; var array2 = ['Doe' , 555 , 100]; Array.prototype.push.call(array1, array2); // 這里用 call 第二個(gè)參數(shù)不會把 array2 當(dāng)成一個(gè)數(shù)組,而是一個(gè)元素 // 等價(jià)于 array1.push("'Doe' , 555 , 100"); // array1.length=5; Array.prototype.push.apply(array1, array2); // 這里用 apply 第二個(gè)參數(shù)是一個(gè)數(shù)組 // 等價(jià)于:  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 屬性,但是他是一個(gè)偽數(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ù)是,返回整個(gè)數(shù)組  Array.isArray(domNodes);// true
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
驗(yàn)證一個(gè)對象的類型可以用
Object.prototype.toString.call(obj)
    
  • 1
bind() 方法

bind() 方法會創(chuàng)建一個(gè) 新函數(shù),稱為綁定函數(shù),當(dāng)調(diào)用這個(gè)綁定函數(shù)時(shí),綁定函數(shù)會以創(chuàng)建它時(shí)傳入 bind() 方法的第一個(gè)參數(shù) 作為 this,傳入 bind() 方法的 第二個(gè)以及以后的參數(shù)加上綁定函數(shù)運(yùn)行時(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); //此時(shí)this已經(jīng)指向了foo,但是用bind()方法并不會立即執(zhí)行,而是創(chuàng)建一個(gè)新函數(shù),如果要直接調(diào)用的話 可以bar.bind(foo)() func(); // 3
    
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

在 Javascript 中,多次 bind() 是無效的。更深層次的原因, bind() 的實(shí)現(xiàn),相當(dāng)于使用函數(shù)在內(nèi)部包了一個(gè) 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

日歷

鏈接

個(gè)人資料

存檔

嫩草影院久久99_老司机午夜网站国内精品久久久久久久久_久久夜色精品国产_国产一级做a爰片久久毛片
<em id="09ttv"></em>
    <sup id="09ttv"><pre id="09ttv"></pre></sup>
    <dd id="09ttv"></dd>

        • 亚洲免费在线观看| 亚洲午夜黄色| 国产伪娘ts一区| 亚洲国产欧洲综合997久久| 亚洲综合三区| 午夜精品国产| 亚洲欧美日韩国产一区二区三区 | 一区免费视频| 久久精品天堂| 美女在线一区二区| 影音先锋在线一区| 老司机午夜精品视频在线观看| 老司机aⅴ在线精品导航| 极品裸体白嫩激情啪啪国产精品| 久久成人一区二区| 欧美激情精品久久久久久变态| 亚洲激情欧美激情| 欧美午夜欧美| 欧美一级二区| 欧美成人伊人久久综合网| 在线精品国精品国产尤物884a| 女人香蕉久久**毛片精品| 亚洲专区在线视频| 欧美一区二区三区在线视频 | 亚洲在线视频观看| 羞羞漫画18久久大片| 亚洲高清三级视频| 亚洲精品久久久蜜桃| 午夜精品福利视频| 伊人色综合久久天天| 女生裸体视频一区二区三区| 亚洲一区bb| 欧美高清成人| 欧美一区二区三区免费观看| 亚洲黄色影院| 国产日本亚洲高清| 欧美黄色一区二区| 亚洲欧美日本国产专区一区| 欧美激情一区二区久久久| 欧美一区二视频| 亚洲高清资源| 国产在线视频不卡二| 欧美日韩亚洲不卡| 欧美二区在线播放| 亚洲女性裸体视频| 最新日韩在线视频| 精品成人免费| 国产一在线精品一区在线观看| 欧美午夜精品电影| 欧美日韩国产探花| 欧美韩日一区| 蜜桃久久精品一区二区| 久久国产精品久久精品国产| 欧美一区二区三区视频在线| 一本色道久久加勒比88综合| 亚洲国产婷婷| 91久久久国产精品| 亚洲电影自拍| 欧美精品成人在线| 麻豆91精品| 免费成人毛片| 欧美va亚洲va日韩∨a综合色| 久久精品视频免费观看| 久久大综合网| 麻豆国产va免费精品高清在线| 久久全球大尺度高清视频| 久久精品日韩| 亚洲日本va午夜在线电影| 亚洲在线免费观看| 午夜精品999| 欧美综合第一页| 久久综合电影| 最新高清无码专区| 亚洲免费观看| 性久久久久久久久久久久| 欧美一级二区| 亚洲二区在线观看| 99riav1国产精品视频| 亚洲婷婷在线| 久久久99爱| 欧美日韩免费| 国产日韩欧美亚洲一区| 在线精品视频在线观看高清| 91久久国产精品91久久性色| 亚洲深夜福利视频| 久久久久综合一区二区三区| 欧美国产精品一区| 制服丝袜激情欧洲亚洲| 久久精品亚洲精品国产欧美kt∨| 欧美xxxx在线观看| 国产伦精品一区二区三区视频孕妇| 国产综合婷婷| 一区二区三区免费网站| 欧美专区在线观看| 亚洲毛片一区| 蜜桃av综合| 黄网动漫久久久| 亚洲一二三四区| 欧美大尺度在线| 欧美亚洲系列| 欧美午夜一区二区| 亚洲黄色免费电影| 久久欧美中文字幕| 午夜精品网站| 国产精品色婷婷久久58| 日韩网站在线看片你懂的| 免费91麻豆精品国产自产在线观看| 中文国产成人精品| 欧美日韩精品二区| 欧美激情四色| 久久久久久久久岛国免费| 国产欧美日本| 亚洲欧美电影院| 99这里只有久久精品视频| 美女在线一区二区| 在线观看日韩欧美| 欧美/亚洲一区| 久久免费一区| 国产精品美女www爽爽爽视频| 欧美特黄一级| 亚洲毛片网站| 亚洲人www| 欧美三区视频| 亚洲欧美中文日韩在线| 一区二区三区久久网| 欧美视频在线观看视频极品| 亚洲香蕉视频| 亚洲中无吗在线| 国产日本欧美在线观看| 久久伊人精品天天| 免费观看成人| 99成人在线| 亚洲一区二区视频| 国产一区二区三区在线观看视频| 久久国产精品久久久久久| 久久精品欧美日韩| 亚洲黄色高清| 亚洲一二三区精品| 国模叶桐国产精品一区| 欧美激情一二区| 国产精品视频1区| 美女网站在线免费欧美精品| 免费影视亚洲| 亚洲欧美日韩在线综合| 欧美.日韩.国产.一区.二区| 久久理论片午夜琪琪电影网| 欧美黄色免费网站| 久久九九免费视频| 欧美片第一页| 久久伊人亚洲| 国产精品你懂的在线欣赏| 欧美成人自拍| 国产女主播视频一区二区| 亚洲精品乱码久久久久久黑人| 国产精品主播| 亚洲伦理自拍| 亚洲欧洲美洲综合色网| 久久成人免费电影| 欧美一级视频一区二区| 欧美日韩午夜视频在线观看| 欧美成人精品高清在线播放| 国产美女精品视频| 一本色道久久综合亚洲精品小说| 在线成人黄色| 欧美与欧洲交xxxx免费观看| 亚洲在线一区二区三区| 欧美大胆成人| 亚洲高清一区二| 亚洲国产婷婷| 免费观看成人鲁鲁鲁鲁鲁视频| 久久综合九色欧美综合狠狠| 国产精品日韩欧美一区二区三区| 亚洲国产欧美一区二区三区丁香婷| 国产亚洲欧洲一区高清在线观看| 新狼窝色av性久久久久久| 欧美激情a∨在线视频播放| 91久久久亚洲精品| 亚洲一区二区在线免费观看| 亚洲精品在线视频观看| 欧美成人乱码一区二区三区| 欧美国产激情二区三区| 亚洲国产裸拍裸体视频在线观看乱了中文| 亚洲欧美一区二区在线观看| 国产精品久久77777| 一区二区三区欧美日韩| 亚洲永久免费视频| 国产麻豆精品视频| 久久精品亚洲精品| 亚洲高清不卡av| 在线亚洲美日韩| 国产欧美日韩一区二区三区在线| 性欧美精品高清| 乱中年女人伦av一区二区| 亚洲美女精品久久| 国产精品免费久久久久久| 午夜久久黄色| 欧美高清在线精品一区| 亚洲无线一线二线三线区别av| 国产欧美日本一区二区三区| 久久爱另类一区二区小说|