js里面的實(shí)例方法和靜態(tài)方法

靜態(tài)方法是可以直接用類名.方法名去調(diào)用的,而實(shí)例方法是不可以的,他必須要用實(shí)例才可以去調(diào)用。

var Person=function(){};
Person.say=function(){
    console.log('I am a Person,I can say.')
};
Person.prototype.getName=function(name){
    console.log('My name is '+name);
}

以上的代碼,實(shí)際上很簡單,首先是定義了一個(gè)function,js里面像上面那樣定義一個(gè)function實(shí)際上是定義了一個(gè)類,接下來,我給你這個(gè)類添加了一個(gè)say的方法,然后接著給這個(gè)類的prototype添加了一個(gè)getName的方法,所有的類都是會(huì)有一個(gè)prototype這樣的屬性,這個(gè)屬性指向的是object,這個(gè)是屬于js原型鏈的問題,在這里我就不闡述了。好了,我現(xiàn)在來按照以下調(diào)用一下:

Person.say();
Person.getName('Carl');

是不是發(fā)現(xiàn),第一個(gè)可以正常運(yùn)行,第二個(gè)會(huì)報(bào)錯(cuò),再來看看下面的代碼:

var carl=new Person;
carl.say();
carl.getName('Carl');

是不是和第一段代碼剛好相反,那么這個(gè)地方實(shí)際上我們就看出來了,say方法是’.’在類上面的,所以,它實(shí)際上是一個(gè)靜態(tài)方法,那么當(dāng)然是可以直接通過類進(jìn)行訪問的(這里的靜態(tài)方法都是public的),所以第一段的第一句話是不會(huì)抱錯(cuò)的,而getName這個(gè)方法實(shí)際上是在prototype上面的,只有創(chuàng)建一個(gè)實(shí)例的情況下,才可以通過實(shí)例進(jìn)行訪問。 所以綜上所述,定義在直接用類名(這里就是方法名)’.’一個(gè)方法,那么這個(gè)實(shí)際上創(chuàng)建的是一個(gè)靜態(tài)方法;而用prototype’.’的一個(gè)方法,實(shí)際上創(chuàng)建的是一個(gè)實(shí)例方法,實(shí)例方法是需要?jiǎng)?chuàng)建實(shí)例對(duì)象進(jìn)行訪問的,所以,以上就是我想說的,js里面的靜態(tài)方法和實(shí)例方法,同樣,靜態(tài)屬性和實(shí)例屬性也是這個(gè)道理。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容