|
1、構(gòu)造函數(shù)方式
復(fù)制代碼 代碼如下:
/**
* Person類:定義一個(gè)人,有個(gè)屬性name,和一個(gè)getName方法
* @param {String} name
*/
function Person(name) {
this.name = name;
this.getName = function() {
return this.name;
}
}
這種風(fēng)格讓我們這些寫過Java的有點(diǎn)親切在于構(gòu)造一個(gè)對(duì)象需要配置一些參數(shù),參數(shù)要賦值給類里面this。但與Java的區(qū)別是js用function來定義類,參數(shù)也無需定義類型。
類寫好了,我們?cè)鞄讉€(gè)對(duì)象:
復(fù)制代碼 代碼如下:
var p1 = new Person("Jack");
var p2 = new Person("Tom");
console.log(p1 instanceof Person);//true
console.log(p2 instanceof Person);//true
控制臺(tái)輸出也證明了p1,p2的確是類Person的對(duì)象實(shí)例。
這種方式的優(yōu)點(diǎn)是:可以根據(jù)參數(shù)來構(gòu)造不同的對(duì)象實(shí)例 ,缺點(diǎn)是構(gòu)造時(shí)每個(gè)實(shí)例對(duì)象都會(huì)生成getName方法版本,造成了內(nèi)存的浪費(fèi) 。
當(dāng)然經(jīng)驗(yàn)豐富的程序員用一個(gè)外部函數(shù)來代替類方法,達(dá)到了每個(gè)對(duì)象共享同一個(gè)方法。改寫后的類如下:
復(fù)制代碼 代碼如下:
//外部函數(shù)
function getName() {
return this.name;
}
function Person(name) {
this.name = name;
this.getName = getName;//注意這里
}
呵呵,有人可能覺得代碼風(fēng)格有點(diǎn)差強(qiáng)人意,怎么看也沒有Java那么緊湊。但的確可以減少內(nèi)存的消耗。
JavaScript技術(shù):javascript 寫類方式之一,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。