欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中函數(shù)(Function)的apply與call理解

 更新時間:2015年07月08日 09:52:53   投稿:junjie  
這篇文章主要介紹了JavaScript中函數(shù)(Function)的apply與call理解,本文講解了JavaScript函數(shù)調用分為4中模式以及通過apply和call實現(xiàn)擴展和繼承兩方面,需要的朋友可以參考下

JavaScript函數(shù)調用分為4中模式:

1. 方法調用模式:即對象包含方法屬性,Obj.methodName()或者Obj[methodName]()。
2. 函數(shù)調用模式:即methodName()。
3. 構造器調用模式:即new MethodName()。
4. apply和call調用模式:即ObjA.apply(ObjB,args[])或者ObjA.call(ObjB,arg1,arg2...)。

函數(shù)調用時,除了接收形式參數(shù)外,還會接收this和arguments。其中this為函數(shù)對象上下文,arguments為實際參數(shù)。
apply和call實現(xiàn)同樣的功能,即切換函數(shù)對象的上下文(this指向的引用),區(qū)別在于形式參數(shù)不一樣。apply為arguments或者數(shù)組,call為以逗號隔開多個單獨形式參數(shù)。

function add(c) 
{ 
  alert(this.a+this.b+c); 
} 
var test={a:1,b:2} 
add.call(test,3);


在執(zhí)行add.call(test,3); 之前add和test都屬于window下,此時this指向window。add.call(test,3); 執(zhí)行時,進入add方法體,此時this由window切換為test,此時this.a=test.a,this.b=test.b,c為形式參數(shù)傳入的值,即alert()的結果為1+2+3=6。apply也是一樣的功能。
 
通過apply和call實現(xiàn)擴展和繼承:

function Animal(name){   
   this.name = name;   
   this.showName = function(){   
     alert(this.name);   
   }   
 }   
   
 function Cat(name){  
   Animal.call(this, name); 
 }   
   
 var cat = new Cat("Black Cat");//執(zhí)行時,Cat函數(shù)體的this由window切換為Cat{}, 
// Animal函數(shù)體的this.name通過形式參數(shù)傳入即為Black Cat,最終cat 
 //得到的結果為cat=Cat{name:"Black Cat",showName: function(){ alert(this.name);}, 
 cat.showName();//執(zhí)行時this由window切換為 
 //Cat{name:"Black Cat",showName: function(){ alert(this.name);} 此時this.name 
 //為this.name=Cat.name,因此為Black Cat。

相關文章

  • JS中bridge的原理與封裝

    JS中bridge的原理與封裝

    這篇文章主要介紹了JS中bridge的原理與封裝,文章圍繞主題的相關資料展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-06-06
  • 小程序中英文混合排序問題解決

    小程序中英文混合排序問題解決

    這篇文章主要介紹了小程序中英文混合排序問題解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • js用閉包遍歷樹狀數(shù)組的方法

    js用閉包遍歷樹狀數(shù)組的方法

    這篇文章主要介紹了js中用閉包遍歷樹狀數(shù)組的方法,需要的朋友可以參考下
    2014-03-03
  • bootstrap 路徑導航 分頁 進度條的實例代碼

    bootstrap 路徑導航 分頁 進度條的實例代碼

    本文通過實例代碼給大家介紹了bootstrap 路徑導航 分頁 進度條的相關知識,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-08-08
  • 關于Error:Unknown?option?'--inline'報錯的解決辦法

    關于Error:Unknown?option?'--inline'報錯的解決辦法

    這篇文章主要給大家介紹了關于Error:Unknown?option?'--inline'報錯的解決辦法,文中將解決的辦法介紹的非常詳細,對大家的學習或者工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • 微信小程序實現(xiàn)發(fā)動態(tài)功能的示例代碼

    微信小程序實現(xiàn)發(fā)動態(tài)功能的示例代碼

    最近做了一個校園拍賣小程序,想在里面添加一個類似校園圈功能,現(xiàn)在來一步一步實現(xiàn),對微信小程序實現(xiàn)發(fā)動態(tài)功能感興趣的朋友一起看看吧
    2022-08-08
  • JS實現(xiàn)頁面打印功能

    JS實現(xiàn)頁面打印功能

    本文主要介紹了JS實現(xiàn)頁面打印功能的方法,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • JavaScript實現(xiàn)長圖滾動效果

    JavaScript實現(xiàn)長圖滾動效果

    這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)長圖滾動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • Javascript將string類型轉換int類型

    Javascript將string類型轉換int類型

    今天網(wǎng)站有個小功能要判斷用戶購買商品數(shù)量是否大于庫存數(shù)據(jù),如果大于庫存數(shù)量,就給予提示。
    2010-12-12
  • 鼠標滾輪編程

    鼠標滾輪編程

    鼠標滾輪編程...
    2007-01-01

最新評論