對(duì)象

對(duì)象可以通過(guò)兩種形式定義:聲明(文字)形式和構(gòu)造形式。

var myObj = { 文字形式超燃。

key: value

// ...

};

var myObj = new Object(); 構(gòu)造形式妹窖。

myObj.key = value;

構(gòu)造形式和文字形式生成的對(duì)象是一樣的。唯一的區(qū)別是,在文字聲明中你可以添加多個(gè)鍵 / 值對(duì)凑术,但是在構(gòu)造形式中你必須逐個(gè)添加屬性。

內(nèi)容

var myObject = {

a: 2

};

myObject.a; // 2? 屬性訪(fǎng)問(wèn)

myObject["a"]; // 2 ?鍵訪(fǎng)問(wèn)

這兩種語(yǔ)法的主要區(qū)別在于 . 操作符要求屬性名滿(mǎn)足標(biāo)識(shí)符的命名規(guī)范所意,而 [".."] 語(yǔ)法可以接受任意 UTF-8/Unicode 字符串作為屬性名淮逊。舉例來(lái)說(shuō),如果要引用名稱(chēng)為 "SuperFun!"的屬性扶踊,那就必須使用 ["Super-Fun!"] 語(yǔ)法訪(fǎng)問(wèn)泄鹏,因?yàn)?Super-Fun! 并不是一個(gè)有效的標(biāo)識(shí)符屬性名。

對(duì)象中屬性永遠(yuǎn)是字符串 ?字面量 秧耗。NUMBER OBJECT都不例外备籽。會(huì)給轉(zhuǎn)為STRING。數(shù)組是數(shù)字分井。區(qū)分對(duì)象和數(shù)組车猬。

可計(jì)算屬性名

? ?健訪(fǎng)問(wèn)派上用場(chǎng)了霉猛!

? ?ES6 增加了可計(jì)算屬性名,可以在文字形式中使用 [] 包裹一個(gè)表達(dá)式來(lái)當(dāng)作屬性名:

? ?例如:

var prefix = "foo";

var myObject = {

[prefix + "bar"]:"hello",

[prefix + "baz"]: "world"

};

myObject["foobar"]; // hello

myObject["foobaz"]; // world

屬性與方法

? ? ? ?屬性是個(gè)函數(shù)珠闰,開(kāi)發(fā)者喜歡叫為方法惜浅。

數(shù)組

復(fù)制對(duì)象


屬性描述符

var myObject = {

a:2

};

Object.getOwnPropertyDescriptor( myObject, "a" );

// {

// value: 2,

// writable: true,

// enumerable: true,

// configurable: true

// }

writable(可寫(xiě))、enumerable(可枚舉)和 configurable(可配置)伏嗜。

? 1. Writable

? ?writable 決定是否可以修改屬性的值坛悉。

? ?writable: false, // 不可寫(xiě)! 對(duì)對(duì)象的屬性修改就無(wú)效阅仔。

? 2. Configurable

? 只要屬性是可配置的吹散,就可以使用 defineProperty(..) 方法來(lái)修改屬性描述符:

? configurable:false

? 把 writable 的狀態(tài)由 true 改為 false,但是無(wú)法由 false 改為 true八酒。

? 除了無(wú)法修改空民,configurable:false 還會(huì)禁止刪除這個(gè)屬性:

? 3. Enumerable

? 從名字就可以看出,這個(gè)描述符控制的是屬性是否會(huì)出現(xiàn)在對(duì)象的屬性枚舉中羞迷,比如說(shuō)

? for..in 循環(huán)界轩。如果把 enumerable 設(shè)置成 false,這個(gè)屬性就不會(huì)出現(xiàn)在枚舉中衔瓮,雖然仍

? 然可以正常訪(fǎng)問(wèn)它浊猾。相對(duì)地,設(shè)置成 true 就會(huì)讓它出現(xiàn)在枚舉中热鞍。

? ?用戶(hù)定義的所有的普通屬性默認(rèn)都是 enumerable葫慎,這通常就是你想要的。但是如果你不希

? ?望某些特殊屬性出現(xiàn)在枚舉中薇宠,那就把它設(shè)置成 enumerable:false偷办。

? 對(duì)象常量

? 結(jié)合 writable:false 和 configurable:false 就可以創(chuàng)建一個(gè)真正的常量屬性(不可修改、重定義或者刪除):

? 禁止擴(kuò)展

? Object.preventExtensions(..)

? 密封

?Object.seal(..) 會(huì)創(chuàng)建一個(gè)“密封”的對(duì)象澄港,這個(gè)方法實(shí)際上會(huì)在一個(gè)現(xiàn)有對(duì)象上調(diào)用

?Object.preventExtensions(..) 并把所有現(xiàn)有屬性標(biāo)記為 configurable:false椒涯。

?所以,密封之后不僅不能添加新屬性回梧,也不能重新配置或者刪除任何現(xiàn)有屬性(雖然可以

?修改屬性的值)废岂。

? ?凍結(jié)

? Object.freeze(..) 會(huì)創(chuàng)建一個(gè)凍結(jié)對(duì)象,這個(gè)方法實(shí)際上會(huì)在一個(gè)現(xiàn)有對(duì)象上調(diào)用Object.seal(..) 并把所有“數(shù)據(jù)訪(fǎng)問(wèn)”屬性標(biāo)記為 writable:false狱意, ? ? 這樣就無(wú)法修改它們的值湖苞。

?Getter和Setter

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市髓涯,隨后出現(xiàn)的幾起案子袒啼,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蚓再,死亡現(xiàn)場(chǎng)離奇詭異滑肉,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)摘仅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)靶庙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人娃属,你說(shuō)我怎么就攤上這事六荒。” “怎么了矾端?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵掏击,是天一觀(guān)的道長(zhǎng)。 經(jīng)常有香客問(wèn)我秩铆,道長(zhǎng)砚亭,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任殴玛,我火速辦了婚禮捅膘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘滚粟。我一直安慰自己寻仗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布凡壤。 她就那樣靜靜地躺著署尤,像睡著了一般。 火紅的嫁衣襯著肌膚如雪亚侠。 梳的紋絲不亂的頭發(fā)上沐寺,一...
    開(kāi)封第一講書(shū)人閱讀 51,443評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音盖奈,去河邊找鬼。 笑死狐援,一個(gè)胖子當(dāng)著我的面吹牛钢坦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播啥酱,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼爹凹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了镶殷?” 一聲冷哼從身側(cè)響起禾酱,我...
    開(kāi)封第一講書(shū)人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后颤陶,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體颗管,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年滓走,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了垦江。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡搅方,死狀恐怖比吭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情姨涡,我是刑警寧澤衩藤,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布,位于F島的核電站涛漂,受9級(jí)特大地震影響赏表,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜怖喻,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一底哗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧锚沸,春花似錦跋选、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至距潘,卻和暖如春炼列,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背音比。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工俭尖, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人洞翩。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓稽犁,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親骚亿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子已亥,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

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

  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持,譯者再次奉上一點(diǎn)點(diǎn)福利:阿里云產(chǎn)品券来屠,享受所有官網(wǎng)優(yōu)惠虑椎,并抽取幸運(yùn)大...
    HetfieldJoe閱讀 2,592評(píng)論 9 22
  • 特別說(shuō)明震鹉,為便于查閱,文章轉(zhuǎn)自https://github.com/getify/You-Dont-Know-JS...
    殺破狼real閱讀 671評(píng)論 0 1
  • 對(duì)象 對(duì)象可以通過(guò)兩種形式定義: 聲明形式和構(gòu)造形式 聲明形式語(yǔ)法: var myObj = {key:value...
    qhaobaba閱讀 331評(píng)論 0 0
  • 概述 JavaScript提供了一個(gè)內(nèi)部數(shù)據(jù)結(jié)構(gòu)捆姜,用來(lái)描述一個(gè)對(duì)象的屬性的行為传趾,控制它的行為。這被稱(chēng)為“屬性描述對(duì)...
    zjh111閱讀 724評(píng)論 0 0
  • 盡管javascript里有大量?jī)?nèi)建引用對(duì)象娇未,很可能你還說(shuō)會(huì)頻繁創(chuàng)建自己的對(duì)象墨缘。當(dāng)你在這么做的時(shí)候,記得javas...
    WanLum閱讀 531評(píng)論 1 3