• <abbr id="chdyf"></abbr>
    <ruby id="chdyf"><acronym id="chdyf"><meter id="chdyf"></meter></acronym></ruby>
    <bdo id="chdyf"></bdo>
    <dfn id="chdyf"><menu id="chdyf"></menu></dfn>
    1. <menuitem id="chdyf"></menuitem><strong id="chdyf"><menu id="chdyf"></menu></strong>

      <rt id="chdyf"><menu id="chdyf"></menu></rt>
      成人小说一区二区三区,伊人精品成人久久综合全集观看,久久HEZYO色综合,中文字幕精品人妻熟女,影音先锋成人网站,我要看免费一级毛片,中国女人做爰A片,中文字幕av久久爽Av

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

      2018-4-22    seo達人

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

      三種方法的作用

      在 JavaScript 中

      1. callapply 和 bind 是 Function 對象自帶的三個方法,都是為了改變函數體內部 this 的指向。
      2. callapply 和 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.wtxcl.cn

      存檔

      主站蜘蛛池模板: 午夜成人三级| 欧美成人18| 男人天堂国产| www.亞洲色| 97人人模人人爽视频一区二区| 福利姬福利库 网站入口| 人人妻人人澡人人爽人人精品97| 亚洲色人| 国产美女视频一区二区三区| 中文字幕在线网址| 亚洲啊v.在线播放| 中文字幕av久久波多野结| 亚欧美日韩香蕉在线播放视频| 国产成人区在线观看视频| 精品国产女同疯狂摩擦2| 美女一级毛片免费观看97| 亚洲欧美一区二区不卡精品| 精品亚洲成在人线av无码| 国产精品极品美女自在线| 亚欧图综合亚洲欧洲日韩国产 | 拜城县| 无码人妻AV| 国产精品96久久久久久| 中文字幕一区二区三| 亚洲另类图| 网红主播国产一区在线| 青青久草| jizzjizzjizzjizz| 亚洲伊人狼人在线视频| 18岁以下禁止观看的网站| 日本一区二区中文字幕| 岳的下面好紧好爽视频| 99精品视频在线观看免费蜜桃| 中国A片乱子伦| jiZZjiZZ欧美69| 亚洲精品视频免费看| av成人天堂在线观看| 丁香五月影院| 亚洲视频播放| 国产丝袜精品在线播放| 亚洲欧美va天堂人熟伦|