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

js call方法詳細(xì)介紹(js 的繼承)

 更新時(shí)間:2013年11月18日 15:53:37   作者:  
這篇文章主要介紹了js call方法使用方法,有需要的朋友可以參考一下

call 方法
請(qǐng)參閱
應(yīng)用于:Function 對(duì)象
要求
版本 5.5
調(diào)用一個(gè)對(duì)象的一個(gè)方法,以另一個(gè)對(duì)象替換當(dāng)前對(duì)象。

call([thisObj[,arg1[, arg2[, [,.argN]]]]])
參數(shù)
thisObj
可選項(xiàng)。將被用作當(dāng)前對(duì)象的對(duì)象。
arg1, arg2, , argN
可選項(xiàng)。將被傳遞方法參數(shù)序列。
說(shuō)明
call 方法可以用來(lái)代替另一個(gè)對(duì)象調(diào)用一個(gè)方法。call 方法可將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象。

如果沒(méi)有提供 thisObj 參數(shù),那么 Global 對(duì)象被用作 thisObj。

-------------------------------------------------------------------------------------------
乍一看,很容易把人看迷胡,先做一些簡(jiǎn)單的說(shuō)明
obj1.method1.call(obj2,argument1,argument2)
如上,call的作用就是把obj1的方法放到obj2上使用,后面的argument1..這些做為參數(shù)傳入.

舉一個(gè)具體的例子

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

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

add.call(sub,3,1);


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


看一個(gè)稍微復(fù)雜一點(diǎn)的例子

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

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í)行,原來(lái)c2是沒(méi)有showNam() 方法,現(xiàn)在是把c1 的showNam()方法放到 c2 上來(lái)執(zhí)行,所以this.name 應(yīng)該是 class2,執(zhí)行的結(jié)果就是 :alert("class2");

怎么樣,覺(jué)得有意思了吧,可以讓a對(duì)象來(lái)執(zhí)行b對(duì)象的方法,這是java程序員所不敢想的。還有更有趣的,可以用 call 來(lái)實(shí)現(xiàn)繼承

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

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 對(duì)象代替this對(duì)象,那么 Class2 中不就有Class1 的所有屬性和方法了嗎,c2 對(duì)象就能夠直接調(diào)用Class1 的方法以及屬性了,執(zhí)行結(jié)果就是:alert(“cc”);

對(duì)的,就是這樣,這就是 javaScript 如何來(lái)模擬面向?qū)ο笾械睦^承的,還可以實(shí)現(xiàn)多重繼承。

復(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è)不屬于本文的范疇,只是在此說(shuō)明call 的用法
說(shuō)了call ,當(dāng)然還有 apply,這兩個(gè)方法基本上是一個(gè)意思
區(qū)別在于 call 的第二個(gè)參數(shù)可以是任意類(lèi)型,而apply的第二個(gè)參數(shù)必須是數(shù)組

相關(guān)文章

  • ES6基礎(chǔ)語(yǔ)法之模塊化介紹

    ES6基礎(chǔ)語(yǔ)法之模塊化介紹

    這篇文章介紹了ES6基礎(chǔ)語(yǔ)法之模塊化,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • JavaScript 中的日期和時(shí)間及表示標(biāo)準(zhǔn)介紹

    JavaScript 中的日期和時(shí)間及表示標(biāo)準(zhǔn)介紹

    本文為大家詳細(xì)介紹下時(shí)間標(biāo)準(zhǔn)指的是什么?UCT和GMT 的概念、關(guān)聯(lián)和區(qū)別?以及時(shí)間表示標(biāo)準(zhǔn)有哪些?感興趣的朋友可以參考下
    2013-08-08
  • 深入理解JavaScript系列(33):設(shè)計(jì)模式之策略模式詳解

    深入理解JavaScript系列(33):設(shè)計(jì)模式之策略模式詳解

    這篇文章主要介紹了深入理解JavaScript系列(33):設(shè)計(jì)模式之策略模式詳解,策略模式定義了算法家族,分別封裝起來(lái),讓他們之間可以互相替換,此模式讓算法的變化不會(huì)影響到使用算法的客戶(hù),需要的朋友可以參考下
    2015-03-03
  • JavascriptES6新特性之map和reduce詳解

    JavascriptES6新特性之map和reduce詳解

    這篇文章主要為大家詳細(xì)介紹了ES6的新特性之map和reduce,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • javascript 構(gòu)造函數(shù)方式定義對(duì)象

    javascript 構(gòu)造函數(shù)方式定義對(duì)象

    這篇文章主要介紹了javascript 構(gòu)造函數(shù)方式定義對(duì)象的方法及示例,需要的朋友可以參考下
    2015-01-01
  • JavaScript對(duì)HTML DOM使用EventListener進(jìn)行操作

    JavaScript對(duì)HTML DOM使用EventListener進(jìn)行操作

    這篇文章主要介紹了JavaScript對(duì)HTML DOM使用EventListener進(jìn)行操作的方法,用于向HTML元素中添加事件,需要的朋友可以參考下
    2015-10-10
  • 關(guān)于JSON的定義以及如何使用

    關(guān)于JSON的定義以及如何使用

    這篇文章主要介紹了關(guān)于JSON的定義以及如何使用,JSON 的名稱(chēng)中雖然帶有JavaScript,但這是指其語(yǔ)法規(guī)則是參考JavaScript對(duì)象的,而不是指只能用于JavaScript語(yǔ)言,需要的朋友可以參考下
    2023-07-07
  • 最新評(píng)論