成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript中call()、apply()、bind()方法特點講解

開發 前端
在javascript中,每個對象中都會有一個apply()方法和一個call()方法,兩者作用是都可以替代另一個對象調用一個方法,將一個函數的上下文改變成由thisObj指向的新對象。

[[406250]]

在javascript中,每個對象中都會有一個apply()方法和一個call()方法

兩者的相同之處:

兩者作用是都可以替代另一個對象調用一個方法,將一個函數的上下文改變成由thisObj指向的新對象

當我們通過call和apply來this的指向時,不傳任何參數,則默認為將this指向修改為windows,有參數時會指向第一個參數

兩者不同之處:

apply最多只能有兩個參數——新this對象和一個數組argArray。如果給該方法傳遞多個參數,則把參數都寫進這個數組里面,當然,即使只有一個參數,也要寫進數組里。如果argArray不是一個有效的數組或arguments對象,那么將導致一個TypeError。如果沒有提供argArray和thisObj任何一個參數,那么Global對象將被用作thisObj,并且無法被傳遞任何參數。

call它可以接受多個參數,第一個參數與apply一樣,后面則是一串參數列表。這個方法主要用在js對象各方法相互調用的時候,使當前this實例指針保持一致,或者在特殊情況下需要改變this指針。如果沒有提供thisObj參數,那么 Global 對象被用作thisObj。

案例:

  1. // apply()方法 
  2. obj.apply(thisObj,['arg1''arg2']) 
  3.  
  4. // call()方法 
  5. obj.call(thisObj,'arg1','arg2','arg3'

 以上thisObj繼承了obj的屬性和方法

  1. // 例1: 
  2. function add(j, k){ 
  3.   return j+k; 
  4.  
  5. function sub(j, k){ 
  6.   return j-k; 
  7.  
  8. // sub繼承了add方法 
  9. console.log(add(5,3)); //8 
  10. console.log(add.call(sub, 5, 3)); //8 
  11. console.log(add.apply(sub, [5, 3])); //8 
  12.  
  13. // add繼承了sub方法 
  14. console.log(sub(5, 3)); //2 
  15. console.log(sub.call(add, 5, 3)); //2 
  16. console.log(sub.apply(add, [5, 3])); //2 
  17.  
  18. // 例2: 
  19. var person = function(){ 
  20.   this.name = "Tom"
  21.   this.age = 22; 
  22. var other = {}; 
  23.  
  24. console.log(other); // {} 
  25. // other繼承了person的屬性 
  26. person.call(other); 
  27. console.log(other); // {name"Tom", age: 22} 

 bind綁定:

call()方法和apply()方法在綁定后會立即執行,而bind則不會立即執行

  1. add.bind(sub, 5, 3); // 返回的是add方法函數本體 
  2. add.bind(sub, 5, 3)(); // 8 

 【編輯推薦】

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2015-03-02 09:22:09

Javascript函數用法apply

2017-10-10 14:36:07

前端Javascriptapply、call、

2024-08-26 14:35:19

JavaScript關鍵字對象

2021-12-05 08:27:56

Javascript 高階函數前端

2024-03-15 08:21:17

bindJavaScrip函數

2024-08-26 08:36:26

2024-08-20 16:04:27

JavaScript開發

2011-03-22 09:49:15

JavaScript

2021-06-09 07:01:30

前端CallApply

2021-11-30 06:56:58

CallApply函數

2023-06-28 08:34:02

Bind()函數JavaScript

2010-04-30 16:08:20

Unix內核

2009-03-10 11:18:13

2009-06-24 11:12:17

callerJavascript

2010-03-03 14:16:48

Python ZipF

2015-12-24 09:48:40

JavaScriptthis指針深

2010-06-17 14:34:18

Rsync 使用

2010-04-30 14:51:23

Unix系統

2010-05-11 20:17:23

NTLM認證協議

2010-01-06 19:18:22

.NET Framew
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品日产欧美久久久久 | 中文二区 | 精品九九久久 | 7799精品视频天天看 | 成人黄视频在线观看 | 久久久国产一区二区三区四区小说 | 91精品国产91 | 久艹网站| 亚洲一区二区三区视频 | 欧美做暖暖视频 | 在线91| 欧美成人精品二区三区99精品 | 成人欧美一区二区三区1314 | 国产欧美日韩综合精品一区二区 | 国产精品国产成人国产三级 | 天天狠狠| 欧美涩涩网 | 欧美色综合一区二区三区 | 97久久久 | 亚洲人成一区二区三区性色 | 日韩中文字幕 | 天堂av中文在线 | 中文字幕加勒比 | 香蕉婷婷 | 中文在线视频 | 人人草人人干 | 中文字幕精品一区 | 国产精品a一区二区三区网址 | 精品视频成人 | 波多野结衣一区二区 | 操到爽 | 奇米久久久 | 欧美日韩亚洲三区 | a级免费黄色片 | 国产亚洲精品美女久久久久久久久久 | 欧美激情久久久久久 | 国产成人高清成人av片在线看 | 欧美亚洲视频 | 九九亚洲 | 久久久久久国产精品免费免费 | 成人精品国产免费网站 |