JavaScript對象創(chuàng)建的幾種方式

1 工廠模式

1.1 創(chuàng)建

function createFruit(name,colors) {
    var o = new Object();
    o.name = name;
    o.colors = colors;
    o.getInfo = function () {
        console.log(this.name+"是"+this.colors+"的");
    }
    return o;
}
var apple = createFruit("蘋果",["紅色","黃色"]);

1.2 說明

利用水果工廠可以很容易的創(chuàng)建一種新的水果,每個新創(chuàng)建的水果都是包括兩個屬性和一個方法的Object。因為沒有水果對象产徊,所以不能通過instanceof得出蘋果是水果的結(jié)論蜀细。

2 構(gòu)造函數(shù)模式

2.1 創(chuàng)建

function Fruit(name,colors) {
    this.name = name;
    this.colors = colors;
    this.getInfo = function () {
        console.log(this.name+"是"+this.colors+"的");
    }
}
var apple = new Fruit("蘋果",["紅色","黃色"]);

2.2 說明

利用構(gòu)造函數(shù)模式可以解決對象識別問題,但其主要問題是每個方法在每個實例上重新創(chuàng)建一遍谆刨,沒有做到方法的重用归斤。

3 原型模式

3.1 創(chuàng)建

function Fruit() {
}
Fruit.prototype.name = "水果";
Fruit.prototype.colors = [];
Fruit.prototype.getInfo = function () {
    console.log(this.name+"是"+this.colors+"的");
}
var apple = new Fruit();
apple.name = "蘋果";

3.2 說明

原型模式?jīng)]辦法向構(gòu)造函數(shù)傳遞參數(shù),原型中所有的屬性是被多實例共享的脏里,對于引用類型的共享屬性的操作可能引起突出的問題。例如向蘋果的顏色屬性put一個"紅色"(apple.colors.push("紅色"))番舆,哪么所有水果通過原型訪問到的顏色都是"紅色"矾踱,而這是很危險的恨狈。

4 組合模式(構(gòu)造函數(shù)與原型)

4.1 創(chuàng)建

function Fruit(name,colors) {
    this.name = name;
    this.colors = colors;
}
Fruit.prototype = {
    constructor : Fruit,
    getInfo : function () {
        console.log(this.name+"是"+this.colors+"的");
    }
}
var apple = new Fruit("蘋果",["紅色","黃色"]);

4.2 說明

組合模式是最常見的創(chuàng)建自定義對象的方式禾怠,構(gòu)造函數(shù)模式用于定義實例屬性圣蝎,原型模式用于定義方法和共享屬性∨枪可以最大限度的節(jié)省內(nèi)存。

5 動態(tài)原型模式

5.1 創(chuàng)建

function Fruit(name,colors) {
    this.name = name;
    this.colors = colors;
    if(typeof  this.getInfo != "function") {
        Fruit.prototype.getInfo = function () {
            console.log(this.name+"是"+this.colors+"的");
        };
    }
}
var apple = new Fruit("蘋果",["紅色","黃色"]);

5.2 說明

很完美的方式坦袍,把所有信息都封裝在構(gòu)造函數(shù)中。只有在getInfo()方法不存在的情況下捂齐,才會將它添加到原型中缩抡。原型的這段代碼只會在初次調(diào)用構(gòu)造函數(shù)時才會執(zhí)行。

6 寄生構(gòu)造函數(shù)模式

6.1 創(chuàng)建

function Fruit(name,colors) {
    var o = {};
    o.name = name;
    o.colors = colors;
    o.getInfo = function () {
        console.log(this.name+"是"+this.colors+"的");
    }
    return o;
}
var apple = new Fruit("蘋果",["紅色","黃色"]);

6.2 說明

這種方式和工廠模式代碼其實是一樣的压真,只是函數(shù)名采用了Fruit的首字母大寫的形式,并且用new來進行初始化滴肿。這種模式可以在特殊的情況下用來為對象創(chuàng)建構(gòu)造函數(shù)。

7 穩(wěn)妥構(gòu)造函數(shù)模式

7.1 創(chuàng)建

function Fruit(name,colors) {
    var o = {};
    o.getInfo = function () {
        console.log(name+"是"+colors+"的");
    }
    return o;
}
var apple = Fruit("蘋果",["紅色","黃色"]);

7.2 說明

穩(wěn)妥對象(durable objects)是由道格拉斯(douglas)發(fā)明贵少。指的是沒有公共屬性堆缘,并且其方法也不引用this的對象滔灶。適合在安全環(huán)境中實用套啤。

8 摘要

JavaScript自定義對象創(chuàng)建的幾種方式,包括工廠模式、構(gòu)造函數(shù)模式绪氛、原型模式、組合模式(構(gòu)造函數(shù)與原型)争占、動態(tài)原型模式序目、寄生構(gòu)造函數(shù)模式、穩(wěn)妥構(gòu)造函數(shù)模式猿涨。給出了所有7種方式的創(chuàng)建示例代碼及其簡單說明。這幾種創(chuàng)建方式并沒有絕對的好與壞叛赚,不同的方式適合于不同的應(yīng)用場景,大家要靈活選擇肥卡。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末事镣,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子氛琢,更是在濱河造成了極大的恐慌只嚣,老刑警劉巖艺沼,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件障般,死亡現(xiàn)場離奇詭異,居然都是意外死亡挽荡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門于微,熙熙樓的掌柜王于貴愁眉苦臉地迎上來青自,“玉大人,你說我怎么就攤上這事延窜。” “怎么了荠藤?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵获高,是天一觀的道長。 經(jīng)常有香客問我念秧,道長,這世上最難降的妖魔是什么庄吼? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任严就,我火速辦了婚禮,結(jié)果婚禮上梢为,老公的妹妹穿的比我還像新娘轰坊。我一直安慰自己祟印,他們只是感情好,可當我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布颤芬。 她就那樣靜靜地躺著套鹅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪卓鹿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天澜倦,我揣著相機與錄音杰妓,去河邊找鬼藻治。 笑死稚失,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播晴叨,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼初厚!你這毒婦竟也來了孙技?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤牵啦,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后楞件,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡罪针,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年黄伊,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片还最。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡憋活,死狀恐怖岂津,靈堂內(nèi)的尸體忽然破棺而出悦即,到底是詐尸還是另有隱情,我是刑警寧澤辜梳,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布作瞄,位于F島的核電站茶宵,受9級特大地震影響宗挥,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜契耿,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一搪桂、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧踢械,春花似錦、人聲如沸内列。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蕴纳,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間古毛,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工嫂冻, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留塞椎,地道東北人。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓服傍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親吹零。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內(nèi)容