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

實例分析javascript中的call()和apply()方法

 更新時間:2014年11月28日 15:35:11   投稿:hebedich  
因項目需求去研究了下javascript中的call和apply方法,去百度看了幾篇介紹JS中call和apply的文章,總覺得不是很好懂,這里寫下我自己的理解,供網(wǎng)友們參考。

1、方法定義

call方法:
語法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]])
定義:調(diào)用一個對象的一個方法,以另一個對象替換當前對象。
說明:
call 方法可以用來代替另一個對象調(diào)用一個方法。call 方法可將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。
如果沒有提供 thisObj 參數(shù),那么 Global 對象被用作 thisObj。

apply方法:
語法:apply([thisObj[,argArray]])
定義:應用某一對象的一個方法,用另一個對象替換當前對象。
說明:
如果 argArray 不是一個有效的數(shù)組或者不是 arguments 對象,那么將導致一個 TypeError。
如果沒有提供 argArray 和 thisObj 任何一個參數(shù),那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數(shù)。

2、常用實例

a、

復制代碼 代碼如下:

function add(a,b)
{
    alert(a+b);
}
function sub(a,b)
{
    alert(a-b);
}

add.call(sub,3,1);

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

b、

復制代碼 代碼如下:

function Animal(){ 
    this.name = "Animal"; 
    this.showName = function(){ 
        alert(this.name); 
    } 

function Cat(){ 
    this.name = "Cat"; 

var animal = new Animal(); 
var cat = new Cat(); 
//通過call或apply方法,將原本屬于Animal對象的showName()方法交給對象cat來使用了。 
//輸入結果為"Cat" 
animal.showName.call(cat,","); 
//animal.showName.apply(cat,[]);

 call 的意思是把 animal 的方法放到cat上執(zhí)行,原來cat是沒有showName() 方法,現(xiàn)在是把animal 的showName()方法放到 cat上來執(zhí)行,所以this.name 應該是 Cat

c、實現(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");  
 cat.showName();

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

d、多重繼承

復制代碼 代碼如下:

function Class10()
{
    this.showSub = function(a,b)
    {
        alert(a-b);
    }
}
function Class11()
{
    this.showAdd = function(a,b)
    {
        alert(a+b);
    }
}
function Class2()
{
    Class10.call(this);
    Class11.call(this);
}

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

總結:

簡單的說:相同點:兩個方法產(chǎn)生的作用是完全一樣的

不同點:方法傳遞的參數(shù)不同

相關文章

  • 微信和qq時間格式模板實例詳解

    微信和qq時間格式模板實例詳解

    這篇文章主要介紹了微信和qq時間格式模板實例詳解的相關資料,需要的朋友可以參考下
    2016-10-10
  • JavaScript中的typeof操作符用法實例

    JavaScript中的typeof操作符用法實例

    在Web前端開發(fā)中,我們經(jīng)常需要判斷變量的數(shù)據(jù)類型。鑒于ECMAScript是松散類型的,因此需要有一種手段來檢測給定變量的數(shù)據(jù)類型——typeof就是負責提供這方便信息的操作符。
    2014-04-04
  • 淺析四種常見的Javascript聲明循環(huán)變量的書寫方式

    淺析四種常見的Javascript聲明循環(huán)變量的書寫方式

    這篇文章主要介紹了四種常見的聲明循環(huán)變量的書寫方式,對其進行簡單的分析和比較,需要的朋友可以參考下
    2015-10-10
  • javascript中常用編程知識

    javascript中常用編程知識

    javascript雖然只是一個腳本語言,但是它完全也是一個編程語言需要我們來學習一下,下面是轉載的篇關于javascript中常用的編程知識
    2013-04-04
  • 淺談JavaScript數(shù)據(jù)類型及轉換

    淺談JavaScript數(shù)據(jù)類型及轉換

    本文向大家簡單介紹了javascript的數(shù)據(jù)類型以及他們直接的轉換方法,雖然沒有太多示例,但是也是個人的一些經(jīng)驗總結,這里推薦給大家。
    2015-02-02
  • 詳解javascript void(0)

    詳解javascript void(0)

    這篇文章主要介紹了javascript void關鍵字的相關資料,文中講解非常細致,幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-07-07
  • 解決 firefox 不支持 document.all的方法

    解決 firefox 不支持 document.all的方法

    解決 firefox 不支持 document.all的方法...
    2007-03-03
  • javascript基礎知識整理

    javascript基礎知識整理

    這篇文章對于剛開始學習js的朋友,非常有幫助,主要知識點都已經(jīng)整理好了。
    2010-06-06
  • JavaScript開發(fā)規(guī)范要求(規(guī)范化代碼)

    JavaScript開發(fā)規(guī)范要求(規(guī)范化代碼)

    作為一名開發(fā)人員(WEB前端JavaScript開發(fā)),不規(guī)范的開發(fā)不僅使日后代碼維護變的困難,同時也不利于團隊的合作,通常還會帶來代碼安全以及執(zhí)行效率上的問題。
    2010-08-08
  • JavaScript 學習筆記(十四) 正則表達式

    JavaScript 學習筆記(十四) 正則表達式

    RegExp類 RegExp對象的構造函數(shù)可以帶一個或兩個參數(shù) 第一個參數(shù)是描述需要進行匹配的模式字符串,如果還有第二個參數(shù),這個參數(shù)則制定了額外的處理指令。
    2010-01-01

最新評論