(三)創(chuàng)建對象

0.注

本文代碼來自于《JavaScript高級(jí)程序設(shè)計(jì)》一書曼月,非原創(chuàng)谊却,算是小弟讀書筆記。而且我也不認(rèn)為自己寫的實(shí)例代碼能比Zakas的更清晰易懂哑芹。主要記錄下自己認(rèn)為干貨的部分以及加入自己的理解炎辨。文中示意圖等均為原創(chuàng)。

1.對象聪姿?

ECMA的定義:無序?qū)傩缘募喜晗簦鋵傩钥梢园局狄亦帧ο蠡蛘吆瘮?shù)。
我自己的理解破喻,對象就是一個(gè)包含了若干鍵值對的無序列表虎谢。

2.創(chuàng)建對象的方式

  • 工廠模式(其實(shí)并沒什么卵用)
    使用一個(gè)函數(shù)封裝創(chuàng)建對象的全過程:創(chuàng)建一個(gè)臨時(shí)對象、為這個(gè)對象添加屬性曹质、最后將這個(gè)對象返回
  //代碼來自《JavaScript高級(jí)程序設(shè)計(jì)》
   function createPerson(name,age,job) {
       var o = new Object();
       o.name = name;
       o.age = age;
       o.job = job;
       o.sayName = function () {
           alert(this.name);
       };
       return o;
   }
   var person1 = createPerson('gordenZ','24','front-end engineer');
     ```

* 構(gòu)造函數(shù)模式(問題也大婴噩,不會(huì)直接用)
  ```javascript
   //代碼來自《JavaScript高級(jí)程序設(shè)計(jì)》
   function Person(name,age,job) {
       this.name = name;
       this.age = age;
       this.job = job;
       this.sayName = function () {
           alert(this.name);
       };
   }
   var person1 = new Person('gordenZ','24','front-end engineer');
     ```
這個(gè)例子中,創(chuàng)建了一個(gè)構(gòu)造函數(shù)`Person`羽德,并使用`new`操作符實(shí)例化了一個(gè)對象`person1`几莽。
**為何要使用new 操作符?**
想像一下不使用new的情況:
```javascript
var person1 = Person('gordenZ','24','front-end engineer');
 console.log(name);//gordenZ

如果不使用new操作符宅静,相當(dāng)于在當(dāng)前環(huán)境下直接執(zhí)行Person這個(gè)函數(shù)(構(gòu)造函數(shù)也是函數(shù)章蚣,僅僅是第一個(gè)字母大寫了)。這里的執(zhí)行環(huán)境是window姨夹,那么Person中的this就指向了全局的window對象纤垂,所以nameage磷账、job洒忧、sayName等屬性都被創(chuàng)建在了全局對象上,可以直接被訪問到够颠。
new操作符干的事情
1.創(chuàng)建一個(gè)新對象
2.將構(gòu)造函數(shù)的this指向這個(gè)對象(這樣就不再是創(chuàng)建到window上了)
3.執(zhí)行構(gòu)造函數(shù)
4.返回新對象
其實(shí)跟工廠模式?jīng)]有什么區(qū)別嘛
構(gòu)造函數(shù)模式問題:
構(gòu)造函數(shù)模式創(chuàng)建的每個(gè)對象的實(shí)例都是完全獨(dú)立的熙侍,意味著每個(gè)實(shí)例中的屬性都是不同的,這對于值是基本數(shù)據(jù)類型的屬性來說還好履磨,但是對于值是一個(gè)實(shí)現(xiàn)同一功能的函數(shù)的屬性來說就顯得冗余了蛉抓,每一個(gè)實(shí)例都會(huì)有一個(gè)自己的函數(shù),有多少個(gè)實(shí)例就會(huì)創(chuàng)建多少個(gè)相同的函數(shù)(不要忘了剃诅,每個(gè)函數(shù)都是一個(gè)對象)巷送。

  • 原型模式
    js中每一個(gè)函數(shù)都有一個(gè)prototype(即原型)屬性,指向一個(gè)對象矛辕,其功能是保存用這個(gè)函數(shù)類型創(chuàng)建的實(shí)例所共享的屬性和方法笑跛。所以我們可以把需要在各個(gè)實(shí)例上共享的屬性和方法放到這個(gè)類型的prototype中,即可只創(chuàng)建一次而被各實(shí)例所共享聊品。
function Person() {
}
Person.prototype.name = "gordenZ";
Person.prototype.age = "24";
Person.prototype.job = "front-end engineer";
Person.prototype.sayName = function () {
    alert(this.name);
};
 var person1 = new Person();
 var person2 = new Person();

  console.log(person1.sayName === person2.sayName); //true

其中飞蹂,Person構(gòu)造函數(shù)Person.prototype原型對象翻屈、person1person2Person實(shí)例陈哑,這三者的關(guān)系如下圖:

構(gòu)造函數(shù)、原型對象、實(shí)例之間的關(guān)系

每一個(gè)函數(shù)(也就包括了構(gòu)造函數(shù))在創(chuàng)建都會(huì)獲得一個(gè)prototype屬性惊窖,指向了這個(gè)函數(shù)的原型對象刽宪。所有的原型對象都默認(rèn)有一個(gè)constructor·屬性,指向構(gòu)造函數(shù)(Person.prototype.constructor == Person //true)界酒。在根據(jù)構(gòu)造函數(shù)創(chuàng)建的實(shí)例中圣拄,有一個(gè)__proto__指針,指向了該類型的原型對象毁欣。
可以看到庇谆,現(xiàn)在的nameage署辉、jobsayName被所有實(shí)例共享了岩四。
1.每個(gè)實(shí)例又可以添加自己獨(dú)立的屬性

person1.sex = "man"

2.可以在實(shí)例中添加與原型中屬性相同的屬性哭尝,這樣會(huì)屏蔽掉原型中的同名屬性。尋找屬性的方式是剖煌,首先在實(shí)例本身找材鹦,找到了就返回,如果沒有找到耕姊,則到__proto__指針指向的原型對象上尋找桶唐。

person1.name = "grey"
console.log(person1.name) //grey 

3.其他實(shí)例若沒有添加,則不受影響

console.log(person2.name) //gordenZ茉兰。

4.判斷是原型屬性還是實(shí)例屬性:hasOwnProperty()

console.log(person1.hasOwnProperty('name'));//true
console.log(person2.hasOwnProperty('name'));//false

5.判斷對象是否是一個(gè)實(shí)例的原型:isPrototypeOf()

console.log(Person.prototype.isPrototypeOf(person1));//true
console.log(Person.prototype.isPrototypeOf(person1));//true

6.獲取一個(gè)實(shí)例的原型:Object.getPrototypeOf()

console.log(Object.getPrototypeOf(person1) == Person);//true

原型模式的問題
高度共享帶來問題尤泽,在共享的屬性中,如果是數(shù)據(jù)屬性规脸,可以用在實(shí)例上添加同名屬性來屏蔽坯约,但如果某個(gè)屬性是一個(gè)引用類型,那么在任何一個(gè)實(shí)例上對其進(jìn)行修改莫鸭,都會(huì)影響到所有實(shí)例闹丐。

  • 組合使用構(gòu)造函數(shù)模式和原型模式
    1.將每個(gè)實(shí)例自有的屬性寫在構(gòu)造函數(shù)中,即實(shí)例屬性
    2.將所有實(shí)例共享的方法寫在原型對象中被因,即原型屬性
    3.若直接使用對象字面量替換原型對象卿拴,需要將constructor屬性補(bǔ)全
function Person(name,age,job) {
        this.name = name;
        this.age = age;
        this.job = job;
        this.friends = ["aa","bb"];
}
Person.prototype = {
    //補(bǔ)全constructor屬性
    constructor:Person,
    sayName:function () {
       alert(this.name)
    }
};
var person1 = new Person();
var person2 = new Person();
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市梨与,隨后出現(xiàn)的幾起案子堕花,更是在濱河造成了極大的恐慌,老刑警劉巖粥鞋,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件航徙,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)到踏,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門杠袱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人窝稿,你說我怎么就攤上這事楣富。” “怎么了伴榔?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵纹蝴,是天一觀的道長。 經(jīng)常有香客問我踪少,道長塘安,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任援奢,我火速辦了婚禮兼犯,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘集漾。我一直安慰自己切黔,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布具篇。 她就那樣靜靜地躺著纬霞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪驱显。 梳的紋絲不亂的頭發(fā)上诗芜,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天,我揣著相機(jī)與錄音埃疫,去河邊找鬼绢陌。 笑死,一個(gè)胖子當(dāng)著我的面吹牛熔恢,可吹牛的內(nèi)容都是我干的脐湾。 我是一名探鬼主播,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼叙淌,長吁一口氣:“原來是場噩夢啊……” “哼秤掌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起鹰霍,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對情侶失蹤闻鉴,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后茂洒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體孟岛,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了渠羞。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片斤贰。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖次询,靈堂內(nèi)的尸體忽然破棺而出荧恍,到底是詐尸還是另有隱情,我是刑警寧澤屯吊,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布送巡,位于F島的核電站,受9級(jí)特大地震影響盒卸,放射性物質(zhì)發(fā)生泄漏骗爆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一蔽介、第九天 我趴在偏房一處隱蔽的房頂上張望摘投。 院中可真熱鬧,春花似錦屉佳、人聲如沸谷朝。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至杈帐,卻和暖如春体箕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背挑童。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國打工累铅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人站叼。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓娃兽,卻偏偏與公主長得像,于是被迫代替她去往敵國和親尽楔。 傳聞我的和親對象是個(gè)殘疾皇子投储,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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