靜態(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è)道理。