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

JavaScript學習點滴 call、apply的區(qū)別

 更新時間:2010年10月22日 15:19:58   作者:  
對于apply和call兩者在作用上是相同的,但兩者在參數(shù)上有區(qū)別的。
1、call
call 方法
調(diào)用一個對象的一個方法,以另一個對象替換當前對象。
call([thisObj[,arg1[, arg2[, [,.argN]]]]])
參數(shù)
thisObj
可選項。將被用作當前對象的對象。
arg1, arg2, , argN
可選項。將被傳遞方法參數(shù)序列。
說明
call 方法可以用來代替另一個對象調(diào)用一個方法。call 方法可將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。
如果沒有提供 thisObj 參數(shù),那么 Global 對象被用作 thisObj。
簡單的列子(函數(shù)調(diào)用):
復制代碼 代碼如下:

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) ,所以運行結(jié)果為:alert(4); 復雜點的例子(方法調(diào)用):
復制代碼 代碼如下:

function Class1()
{
this.name = "class1";
this.showNam = function()
{
alert(this.name);
}
}
function Class2()
{
this.name = "class2";
}
var c1 = new Class1();
var c2 = new Class2();
c1.showNam.call(c2);

注意,call 的意思是把 c1 的方法放到c2上執(zhí)行,原來c2是沒有showNam() 方法,現(xiàn)在是把c1 的showNam()方法放到 c2 上來執(zhí)行,所以this.name 應該是 class2,執(zhí)行的結(jié)果就是:alert("class2");
實現(xiàn)繼承
復制代碼 代碼如下:

function Class1()
{
this.showTxt = function(txt)
{
alert(txt);
}
}
function Class2()
{
Class1.call(this);
}
var c2 = new Class2();
c2.showTxt("cc");

這樣 Class2 就繼承Class1了,Class1.call(this) 的 意思就是使用 Class1 對象代替this對象,那么 Class2 中不就有Class1 的所有屬性和方法了嗎,c2 對象就能夠直接調(diào)用Class1 的方法以及屬性了,執(zhí)行結(jié)果就是:alert(“cc”);
對的,就是這樣,這就是 javaScript 如何來模擬面向?qū)ο笾械睦^承的,還可以實現(xiàn)多重繼承。

多重繼承

復制代碼 代碼如下:

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ù)組

2、apply

對于apply和call兩者在作用上是相同的,但兩者在參數(shù)上有區(qū)別的。
對于第一個參數(shù)意義都一樣,但對第二個參數(shù):
apply傳入的是一個參數(shù)數(shù)組,也就是將多個參數(shù)組合成為一個數(shù)組傳入,而call則作為call的參數(shù)傳入(從第二個參數(shù)開始)。
如 func.call(func1,var1,var2,var3)對應的apply寫法為:func.apply(func1,[var1,var2,var3])

技巧(代碼優(yōu)雅而其執(zhí)行效率高)
復制代碼 代碼如下:

alert(Math.max(5,8)) //8
alert(Math.max(5,7,9,3,1,6)) //9

var arr=[5,7,9,1]
alert(Math.max.apply(null,arr));

相關文章

  • 多附件上傳組件演示

    多附件上傳組件演示

    多附件上傳組件演示...
    2006-09-09
  • parabola.js拋物線與加入購物車效果的示例代碼

    parabola.js拋物線與加入購物車效果的示例代碼

    本篇文章主要介紹了parabola.js拋物線與加入購物車效果的示例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • H5手機端多文件上傳預覽插件

    H5手機端多文件上傳預覽插件

    這篇文章主要為大家詳細介紹了H5圖片上傳插件,基于zepto,支持多文件上傳,進度和圖片預覽,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 微信公眾平臺 客服接口發(fā)消息的實現(xiàn)代碼(Java接口開發(fā))

    微信公眾平臺 客服接口發(fā)消息的實現(xiàn)代碼(Java接口開發(fā))

    這篇文章主要介紹了微信公眾平臺 客服接口發(fā)消息的實現(xiàn)代碼(Java接口開發(fā)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-04-04
  • 對于Javascript 執(zhí)行上下文的全面了解

    對于Javascript 執(zhí)行上下文的全面了解

    下面小編就為大家?guī)硪黄獙τ贘avascript 執(zhí)行上下文的全面了解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • jquery form表單獲取內(nèi)容以及綁定數(shù)據(jù)

    jquery form表單獲取內(nèi)容以及綁定數(shù)據(jù)

    這篇文章主要介紹了jquery form表單獲取內(nèi)容以及form表單綁定數(shù)據(jù),獲取表單的數(shù)據(jù)保存到數(shù)據(jù)庫,或者將數(shù)據(jù)綁定到form表單,感興趣的小伙伴們可以參考一下
    2016-02-02
  • TypeScript?接口繼承的具體使用

    TypeScript?接口繼承的具體使用

    本文主要介紹了TypeScript?接口繼承的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-07-07
  • 關閉時刷新父窗口兩種方法

    關閉時刷新父窗口兩種方法

    這篇文章主要介紹了刷新父窗口兩種方法,需要的朋友可以參考下
    2014-05-05
  • 最短的IE判斷var ie=!-[1,]分析

    最短的IE判斷var ie=!-[1,]分析

    下面通過分解這個語句來回顧下代碼中所涉及到的javascript知識,需要的朋友可以參考下
    2014-05-05
  • js轉(zhuǎn)html實體的方法

    js轉(zhuǎn)html實體的方法

    下面小編就為大家?guī)硪黄猨s轉(zhuǎn)html實體的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-09-09

最新評論