97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

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.0391cbd.com

存檔

主站蜘蛛池模板: 亚洲欧美日韩高清综合678| 久久精品亚洲中文字幕乱码| 九九视频免费在线观看| 美女无遮挡免费网站| 99无码中文字幕视频| 国产精品污视频| 国产精品女人呻吟在线观看| 热这里只有精品国产热门精品| 亚洲Va中文字幕久久一区| 久久伊伊香蕉综合精品| 国产菊爆视频在线观看| 亚洲第一成年人网站| 国产丝袜91| 538国产视频| 精品欧美一区二区三区久久久| 亚洲人成影视在线观看| 欧美日韩中文字幕二区三区| 美女扒开下面流白浆在线试听| 欧美日一级片| 婷婷久久综合九色综合88| 在线国产资源| 国模私拍一区二区| 在线免费看黄的网站| 国产网站在线看| 亚洲国产成熟视频在线多多| 欧美成人看片一区二区三区| 99资源在线| 亚洲无码免费黄色网址| 高清国产在线| 久久久久久尹人网香蕉| 国产精品不卡片视频免费观看| 欧美福利在线播放| 国产国模一区二区三区四区| 啪啪永久免费av| 亚洲国产看片基地久久1024| 国产欧美视频在线观看| 国产中文一区a级毛片视频| 欧美午夜网站| 久久亚洲国产视频| 99成人在线观看| 成人午夜免费观看| 免费看美女自慰的网站| 永久免费无码日韩视频| 亚洲精品制服丝袜二区| 免费观看无遮挡www的小视频| 国产网友愉拍精品视频| 色妺妺在线视频喷水| 中文天堂在线视频| 亚洲资源站av无码网址| 国产精欧美一区二区三区| 日本午夜在线视频| 青青草一区| 久久亚洲综合伊人| 最近最新中文字幕免费的一页| 国产一区亚洲一区| 在线观看亚洲成人| 国产欧美日韩综合一区在线播放| 伊人久久精品亚洲午夜| 亚洲一区二区视频在线观看| 日韩精品毛片人妻AV不卡| 日本高清免费不卡视频| 国产中文在线亚洲精品官网| 依依成人精品无v国产| 亚洲成AV人手机在线观看网站| 五月天婷婷网亚洲综合在线| 毛片视频网| 2022精品国偷自产免费观看| 香蕉综合在线视频91| 中字无码精油按摩中出视频| 欧美成人一区午夜福利在线| 91精品亚洲| 99国产在线视频| 波多野结衣亚洲一区| 国产成人8x视频一区二区| 国产第三区| 国产黄在线观看| 日韩东京热无码人妻| 欧美激情一区二区三区成人| 亚洲综合专区| 美女被操91视频| 久久国产香蕉| 国产亚洲精久久久久久久91|