ECMAScript的屬性類型

定義只有內(nèi)部才能使用的特性恼蓬,描述了屬性的各種特征蟆炊。是為實(shí)現(xiàn)JavaScript引擎用的。因此在JS中不能直接訪問(wèn)它們膜蛔。

1.數(shù)據(jù)屬性

  • [[Configurable]]表示能否通過(guò)delete刪除屬性從而重新定義屬性坛猪,能否修改屬性的特性,或者能否把屬性修改為訪問(wèn)器屬性皂股。(不可配置)
  • [[Enumerable]]表示能否通過(guò)for-in循環(huán)返回屬性砚哆。
  • [[Writable]]表示能否修改屬性的值。
  • [[Value]]包含這個(gè)屬性的數(shù)據(jù)值屑墨。

要修改屬性默認(rèn)的特性躁锁,必須使用ECMAScript5的Object.defineProperty(屬性所在的對(duì)象,屬性的名字卵史,描述符對(duì)象)方法战转。其中描述符對(duì)象必須是configurable、enumerable以躯、writeable槐秧、value啄踊。設(shè)置其中一個(gè)或多個(gè)值,可以修改對(duì)應(yīng)的特性值刁标。

var person = {
  name: 'Nichole'
};

Object.defineProperty(person, "name", {
  writable: false, // 設(shè)置屬性不可修改
  value: 'Bubble'
});

console.log(person.name); // Bubble
person.name = 'Hello';
// 非嚴(yán)格模式下颠通,該操作被忽略;嚴(yán)格模式下膀懈,會(huì)導(dǎo)致拋出錯(cuò)誤顿锰。
console.log(person.name); // Bubble 

嚴(yán)格模式下拋出錯(cuò)誤

可以多次調(diào)用Object.defineProperty()修改同一屬性,但在把configurable特性設(shè)置為false后就會(huì)有限制了启搂。

2.訪問(wèn)器屬性

訪問(wèn)器屬性不包含數(shù)據(jù)值硼控,它包含一對(duì)getter()setter()函數(shù)。在讀取訪問(wèn)器屬性時(shí)胳赌,會(huì)調(diào)用getter()牢撼,這個(gè)函數(shù)負(fù)責(zé)返回有效的值。在寫(xiě)入訪問(wèn)器屬性時(shí)疑苫,會(huì)調(diào)用setter()并傳入新值熏版,這個(gè)函數(shù)負(fù)責(zé)如何處理數(shù)據(jù)。訪問(wèn)器屬性有如下特性:

  • [[Configurable]]
  • [[Enumerable]]
  • [[Get]]在讀取屬性時(shí)調(diào)用的函數(shù)捍掺,默認(rèn)值為undefined
  • [[Set]]在寫(xiě)入屬性時(shí)調(diào)用的函數(shù)撼短,默認(rèn)值為undefined

訪問(wèn)器屬性不能直接定義,必須使用Object.defineProperty()來(lái)定義乡小。

var person = {
  _name: 'Nichole',
  count: 0
};

Object.defineProperty(person, 'name', {
  get: function () {
    return this._name;
  },
  set: function (newValue) {
    this._name = newValue;
    this.count += 1;
  }
});

person.name = 'Bubble';
console.log(person._name) // Bubble
console.log(person.count) // 1

person對(duì)象有兩個(gè)默認(rèn)屬性:_namecount。而訪問(wèn)器屬性name則包含一個(gè)getter()和一個(gè)setter()饵史。
使用訪問(wèn)器屬性的常見(jiàn)方式即:設(shè)置一個(gè)屬性的值會(huì)導(dǎo)致其他屬性發(fā)生變化满钟。

  1. 如果只指定getter意味著屬性不能寫(xiě);
  2. 如果只指定setter意味著屬性不能讀胳喷。

之前的瀏覽器不支持的使用湃番,使用的是__defineGetter____defineSetter__

定義多個(gè)屬性:

var person = {
  _name: 'Nichole',
  count: 0
};

Object.defineProperties(person, {
    _name: {
      writable: true,
      value: 'Bubble'
    },
    count: {
      writable: true,
      value: 12
    },
    name: {
      get: function () {
        return this._name;
      },
      set: function (newValue) {
        this._name = newValue;
        this.count++;
      }
    }
  }
);
person.name = 'HAH';
console.log(person._name) // HAH
console.log(person.count) // 13

3.讀取屬性的特性

Object.getOwnPropertyDescriptor(person, '_name').configurable

4.擴(kuò)展思考:

Vue動(dòng)態(tài)數(shù)據(jù)綁定如何實(shí)現(xiàn)吭露?

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末吠撮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子讲竿,更是在濱河造成了極大的恐慌泥兰,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件题禀,死亡現(xiàn)場(chǎng)離奇詭異鞋诗,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)迈嘹,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)削彬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)全庸,“玉大人,你說(shuō)我怎么就攤上這事融痛『” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,702評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵雁刷,是天一觀的道長(zhǎng)覆劈。 經(jīng)常有香客問(wèn)我,道長(zhǎng)安券,這世上最難降的妖魔是什么墩崩? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,259評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮侯勉,結(jié)果婚禮上鹦筹,老公的妹妹穿的比我還像新娘。我一直安慰自己址貌,他們只是感情好铐拐,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,263評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著练对,像睡著了一般遍蟋。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上螟凭,一...
    開(kāi)封第一講書(shū)人閱讀 49,036評(píng)論 1 285
  • 那天虚青,我揣著相機(jī)與錄音,去河邊找鬼螺男。 笑死棒厘,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的下隧。 我是一名探鬼主播奢人,決...
    沈念sama閱讀 38,349評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼淆院!你這毒婦竟也來(lái)了何乎?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 36,979評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤土辩,失蹤者是張志新(化名)和其女友劉穎支救,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體拷淘,經(jīng)...
    沈念sama閱讀 43,469評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡搂妻,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,938評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了辕棚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片欲主。...
    茶點(diǎn)故事閱讀 38,059評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡邓厕,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出扁瓢,到底是詐尸還是另有隱情详恼,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評(píng)論 4 323
  • 正文 年R本政府宣布引几,位于F島的核電站昧互,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏伟桅。R本人自食惡果不足惜敞掘,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,257評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望楣铁。 院中可真熱鬧玖雁,春花似錦、人聲如沸盖腕。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,262評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)溃列。三九已至劲厌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間听隐,已是汗流浹背补鼻。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留雅任,地道東北人风范。 一個(gè)月前我還...
    沈念sama閱讀 45,501評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像椿访,于是被迫代替她去往敵國(guó)和親乌企。 傳聞我的和親對(duì)象是個(gè)殘疾皇子虑润,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,792評(píng)論 2 345

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

  • var person = { name: "Nicholas", age: 29, job: "Software ...
    frankisbaby閱讀 557評(píng)論 0 0
  • 1.定義構(gòu)造函數(shù)的兩種方式### 2.屬性類型 ECMAScript 中有兩種屬性:數(shù)據(jù)屬性和訪問(wèn)器屬性成玫。 1. ...
    believedream閱讀 646評(píng)論 0 2
  • 本章內(nèi)容 理解對(duì)象屬性 理解并創(chuàng)建對(duì)象 理解繼承 面向?qū)ο笳Z(yǔ)言有一個(gè)標(biāo)志,那就是它們都有類的概念拳喻,而通過(guò)類可以創(chuàng)建...
    悶油瓶小張閱讀 841評(píng)論 0 1
  • 從es5開(kāi)始哭当,js中開(kāi)始擁有了一種描述屬性特征的特性(即屬性描述符)。根據(jù)特性的不同冗澈,可以把屬性分成兩種類型:數(shù)據(jù)...
    hope7th閱讀 711評(píng)論 0 0
  • 【主辦單位】 無(wú)限思維·杜梁兒童工作室 【協(xié)辦單位】 一堂教育工作室(廣州) 凳子藝術(shù)工作室(長(zhǎng)沙) 智繪空間美學(xué)...
    989ee5f2e56a閱讀 785評(píng)論 0 0