亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

1、方法定義

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

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

2、常用實(shí)例

a、

復(fù)制代碼 代碼如下:

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

add.call(sub,3,1);

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

b、

復(fù)制代碼 代碼如下:

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對(duì)象的showName()方法交給對(duì)象cat來使用了。 
//輸入結(jié)果為"Cat" 
animal.showName.call(cat,","); 
//animal.showName.apply(cat,[]);

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

c、實(shí)現(xiàn)繼承

復(fù)制代碼 代碼如下:

 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對(duì)象代替this對(duì)象,那么 Cat中不就有Animal的所有屬性和方法了嗎,Cat對(duì)象就能夠直接調(diào)用Animal的方法以及屬性了.

d、多重繼承

復(fù)制代碼 代碼如下:

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);
}

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

總結(jié):

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

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

相關(guān)文章

  • 微信和qq時(shí)間格式模板實(shí)例詳解

    微信和qq時(shí)間格式模板實(shí)例詳解

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

    JavaScript中的typeof操作符用法實(shí)例

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

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

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

    javascript中常用編程知識(shí)

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

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

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

    詳解javascript void(0)

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

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

    解決 firefox 不支持 document.all的方法...
    2007-03-03
  • javascript基礎(chǔ)知識(shí)整理

    javascript基礎(chǔ)知識(shí)整理

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

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

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

    JavaScript 學(xué)習(xí)筆記(十四) 正則表達(dá)式

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

最新評(píng)論