JavaScript中改變this的指向方法(call和apple)


1、方法定義

call方法:
語法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]])


定義:調用一個對象的一個方法,以另一個對象替換當前對象。


說明:
call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數的對象上下文從初始的上下文改變為由 thisObj 指定的新對象。

如果沒有提供 thisObj 參數,那么 Global 對象被用作 thisObj

 

apply方法:


語法:apply([thisObj[,argArray]])


定義:應用某一對象的一個方法,用另一個對象替換當前對象。


說明:


如果 argArray 不是一個有效的數組或者不是 arguments 對象,那么將導致一個 TypeError。


如果沒有提供 argArray 和 thisObj 任何一個參數,那么 Global 對象將被用作 thisObj, 並且無法被傳遞任何參數。

 

2、常用實例

a

  1. function add(a,b)  {
  2.   alert(a+b);
  3. }
  4. function sub(a,b) {
  5.   alert(a-b);
  6. }
  7. add.call(sub,3,1);

這個例子中的意思就是用 add 來替換 sub,add.call(sub,3,1) == add(3,1) ,所以運行結果為:alert(4); // 注意:js 中的函數其實是對象,函數名是對 Function 對象的引用。

 

b.實現繼承

  1. function Animal(name){
  2.   this.name = name;
  3.   this.showName=function(){
  4.     alert(this.name);
  5.   }
  6. }
  7.  
  8. functionCat(name){
  9.   Animal.call(this,name);
  10. }
  11.  
  12. varcat=newCat("BlackCat");
  13. cat.showName();

Animal.call(this) 的意思就是使用 Animal對象代替this對象,那么 Cat中不就有Animal的所有屬性和方法了嗎,Cat對象就能夠直接調用Animal的方法以及屬性了.

 

c.多重繼承

  1. function Class10()  
  2. {  
  3.     this.showSub = function(a,b)  
  4.     {  
  5.         alert(a-b);  
  6.     }  
  7. }  
  8.   
  9. function Class11()  
  10. {  
  11.     this.showAdd = function(a,b)  
  12.     {  
  13.         alert(a+b);  
  14.     }  
  15. }  
  16.   
  17. function Class2()  
  18. {  
  19.     Class10.call(this);  
  20.     Class11.call(this);  

很簡單,使用兩個 call 就實現多重繼承了
當然,js的繼承還有其他方法,例如使用原型鏈,這個不屬於本文的范疇,只是在此說明call 的用法。說了call ,當然還有 apply,這兩個方法基本上是一個意思,區別在於 call 的第二個參數可以是任意類型,而apply的第二個參數必須是數組,也可以是arguments
還有 callee,caller..

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM