<strike id="g3zqm"></strike>

      <cite id="g3zqm"></cite>

        <tr id="g3zqm"><center id="g3zqm"></center></tr>
        <pre id="g3zqm"><sup id="g3zqm"></sup></pre>
        <li id="g3zqm"></li>
      1. 少妇高潮激情一区二区三,免费av深夜在线观看,亚洲狼人久久伊人久久伊,久久精品人人做人人爽电影蜜月,黄色特级片一区二区三区,欧美日韩在线亚洲二区综二,极品少妇无套内射视频,日本极品少妇videossexhd

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

        2018-4-22    seo達人

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

        三種方法的作用

        在 JavaScript 中

        1. callapply 和 bind 是 Function 對象自帶的三個方法,都是為了改變函數體內部 this 的指向。
        2. callapply 和 bind 三者第一個參數都是 this 要指向的對象,也就是想指定的上下文
        3. callapply 和 bind 三者都可以利用后續(xù)參數傳參。
        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 的區(qū)別

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

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

        注意bind()方法創(chuàng)建的函數不會立即調用,在下面的例子中,最后 func() 才調用了函數,這是它與 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)建一個新函數,如果要直接調用的話 可以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.hengshangtqd.cn

        存檔

        主站蜘蛛池模板: 久久天天躁夜夜躁狠狠I女人| 国产精品自在拍首页视频8 | 国产精品成人va在线观看| 亚洲AV无码成人精品区国产| 亚洲AV综合一区二区在线观看| 强d乱码中文字幕熟女1000部| 久久zyz资源站无码中文动漫| 国产avav| 韩国无码AV片午夜福利| 色综合国产| 国产久免费热视频在线观看 | 无码熟妇人妻AV在线影片免费 | 国产又黄又爽又不遮挡视频| 亚洲成人av日韩在线| 精品无码毛片| 老司机在线视频导航| 欧美另类videossexo高潮 | 日韩美女乱淫试看视频多人| 国产二区精品久久| 深夜福利姬| 国产日产精品久久久久久| 亚洲国产精品ⅴa在线观看| 少妇无码av无码专区在线观看| 丰满少妇被猛烈进入| 国产精品乱码一区二区三区| 18禁91| 嫩模av一区二区三区| 中文人妻av高清一区二区| 亚洲国产精品男人的天堂| 91视频在线| 亚洲成人人妻| 人妻有码一区二区三区| 4hu44四虎www在线影院麻豆| 少妇人妻偷人精品免费| 亚洲欧美成人一区二区三区| 精品国产亚洲av三区| 亚洲精品自拍| 国产免费播放一区二区三区| 亚洲精品影院| 亚洲日韩Av一区二区三区中文| 国产成人亚洲无码淙合青草|