成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

對象管理器(defineProperty)學習筆記

mist14 / 2636人閱讀

摘要:通過設置我們可以將一些屬性鎖定,來防止別人的修改,這是一種防御編程形式,就像語言的內(nèi)置對象一樣不過的內(nèi)置對象都可以被隨意更改。可以使用來判斷某一個屬性是否可以枚舉。

對象管理器(defineProperty)

在 JavaScript 里面聲明一個變量,通常我們有三種方式可以實現(xiàn):

    let person = {} // 對象字面量
    let cat = new Object() // new 運算符
    let dog = Object.create(null) // create 函數(shù)

我們可以簡單的將 key 值和 value 值賦進去,但在 ES5 中 JavaScript 提供了一個對象管理器的方法給我們,讓我們可以很精細的對每一個屬性定制它們的行為,我們分別可以為屬性設置:

可配置特性(configurable)

可枚舉屬性(enumerable)

可以寫特性(writable)

值(value)

設置 getter 方法(get)

設置 setter 方法(set)

首先讓我們看看如何使用Object.defineProperty來定制屬性吧:

  let person = {}

  Object.defineProperty(person, "name", {
  configurable: true,
  enumerable: true,
  writeable: true,
  value: "_我已經(jīng)從中二畢業(yè)了"
  })

  Object.defineProperty(person, "age", {
  configurable: true,
  enumerable: true,
  writeable: true,
  value: 18
  })

  console.log(person.name) // _我已經(jīng)從中二畢業(yè)了
  console.log(person.age) // 18

通過上面的代碼可以看出 Object.defineProperty 這個函數(shù)能夠接受三個參數(shù):

obj:需要定義屬性的對象

prop:需被定義或修改的屬性名

descriptor:需被定義或修改的屬性的描述符

語法

Object.defineProperty(obj, prop, descriptor)

可配置特性(configurable)

當 configurable 這個屬性為 true 的時候表示這個屬性可以從父對象中刪除。當 configurable 設置為 false 的時候就會鎖定這個屬性,無法被修改。通過設置 configurable 我們可以將一些屬性鎖定,來防止別人的修改,這是一種防御編程形式,就像語言的內(nèi)置對象一樣(不過 JavaScript 的內(nèi)置對象都可以被隨意更改)。

  let person = {}

  Object.defineProperty(person, "name", {
  configurable: false,
  value: "_我已經(jīng)從中二畢業(yè)了"
  })

  Object.defineProperty(person, "age", {
  configurable: true,
  value: 18
  })

  delete person.name
  console.log(person.name) // _我已經(jīng)從中二畢業(yè)了

  delete person.age
  console.log(person.age) // undefined

  person.name = "John"
  console.log(person.name) // _我已經(jīng)從中二畢業(yè)了

  person.age = 19
  console.log(person.age) // 19
可枚舉屬性(enumerable)

一般來說我們會通過for in操作來遍歷可以枚舉的屬性。當然我們也可以設置屬性為不可枚舉,這些屬性就不能夠被枚舉了,從而防止遍歷查找到這個屬性。可以使用 propertyIsEnumerable 來判斷某一個屬性是否可以枚舉。

  let person = {}

  Object.defineProperty(person, "name", {
    enumerable: true,
    value: "_我已經(jīng)從中二畢業(yè)了"
  })

  Object.defineProperty(person, "age", {
    enumerable: false,
    value: 18
  })
    
  // 只輸出了 name    
  for (var key in person) {
    console.log(key)
  }

  console.log(Object.keys(person)) // ["name"]
  console.log(Object.getOwnPropertyNames(person)) // ["name", "age"]
  console.log(person.propertyIsEnumerable("name")) // true
  console.log(person.propertyIsEnumerable("age")) // false
  console.log(person.age) // 18
可以寫特性(writable)

當 writable 為 true 的時候,與屬性相關聯(lián)的值是可以更改的。否則,值就不能改變。

  let person = {}
  let person2 = person

  Object.defineProperty(person, "name", {
    writable: false,
    value: "_我已經(jīng)從中二畢業(yè)了"
  })

  Object.defineProperty(person, "age", {
    writable: true,
    value: 18
  })

  person.name = "John"
  console.log(person.name) // _我已經(jīng)從中二畢業(yè)了
  console.log(person2.name) // _我已經(jīng)從中二畢業(yè)了

  person.age = 19
  console.log(person.age) // 19
  console.log(person.age) // 19

  person2.name = "John"
  console.log(person.name) // _我已經(jīng)從中二畢業(yè)了
  console.log(person2.name) // _我已經(jīng)從中二畢業(yè)了

  person2.age = 20
  console.log(person.age) // 20
  console.log(person.age) // 20
相關鏈接

Object.defineProperty()

Object.keys()

Object.getOwnPropertyNames()

Object.prototype.propertyIsEnumerable()

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/79332.html

相關文章

  • JS學習筆記(第6章)(面向對象的程序設計之理解對象

    摘要:其中,描述符對象的屬性必須是和。吧設置為,表示不能從對象中刪除屬性。這個方法接收兩個對象參數(shù)要添加和修改其屬性值的對象,第二個是與第一個對象中要添加和修改的屬性值一一對應。 理解對象 1、創(chuàng)建自定義對象的兩種方法: (1)創(chuàng)建一個Object實例,然后再為它添加屬性和方法。 var person = new Object(); person.name = Nicholas; ...

    FingerLiu 評論0 收藏0
  • vue數(shù)據(jù)雙向綁定學習筆記。

    摘要:訂閱者的實現(xiàn)如下將自己添加到訂閱器的操作緩存自己強行執(zhí)行監(jiān)聽器里的函數(shù)釋放自己到此為止,簡單版的設計完畢,這時候我們需要將和關聯(lián)起來,就可以實現(xiàn)一個簡單的雙向數(shù)據(jù)綁定了。同樣使用數(shù)據(jù)劫持。。 什么是雙向綁定 簡單說就是在數(shù)據(jù)和UI之間建立雙向的通信通道,當用戶通過Function改變了數(shù)據(jù),那么這個改變也會立即反映到UI上;或者說用戶通過UI的操作也會隨之引起對應的數(shù)據(jù)變動。Vue是如...

    huashiou 評論0 收藏0
  • JavaScript Object.defineProperty()學習筆記。

    摘要:數(shù)據(jù)屬性有個描述其行為的特性。表示能否通過刪除屬性從而重新定義屬性,能否修改屬性的特性,或者能否把屬性修改為訪問器屬性。表示能否修改屬性的值。其中,描述符對象的屬性必須是和。返回值被傳遞給函數(shù)的對象。 屬性類型 ECMAScript中有兩種屬性:數(shù)據(jù)屬性和訪問器屬性。數(shù)據(jù)屬性:數(shù)據(jù)屬性包含一個數(shù)據(jù)值的位置。在這個位置可以讀取和寫入值。數(shù)據(jù)屬性有4個描述其行為的特性。 [[Configu...

    lushan 評論0 收藏0
  • 《你不知道的javascript》筆記_對象&原型

    摘要:上一篇你不知道的筆記寫在前面這是年第一篇博客,回顧去年年初列的學習清單,發(fā)現(xiàn)僅有部分完成了。當然,這并不影響年是向上的一年在新的城市穩(wěn)定連續(xù)堅持健身三個月早睡早起游戲時間大大縮減,學會生活。 上一篇:《你不知道的javascript》筆記_this 寫在前面 這是2019年第一篇博客,回顧去年年初列的學習清單,發(fā)現(xiàn)僅有部分完成了。當然,這并不影響2018年是向上的一年:在新的城市穩(wěn)定、...

    seasonley 評論0 收藏0
  • vue 雙向數(shù)據(jù)綁定的實現(xiàn)學習(一)

    摘要:雙向數(shù)據(jù)綁定簡言之數(shù)據(jù)動頁面動,頁面動,數(shù)據(jù)動典型的應用就是在做表單時候,輸入框的內(nèi)容改動后,跟該輸入框的的值改動??垂倬W(wǎng)上的這個的演示案例雙向數(shù)據(jù)綁定的好處要說出這個好處的時候,也只有在實際場景中才能對應的顯示出來。 前言:本系列學習筆記從以下幾個點展開 什么是雙向數(shù)據(jù)綁定 雙向數(shù)據(jù)綁定的好處 怎么實現(xiàn)雙向數(shù)據(jù)綁定 實現(xiàn)雙向數(shù)據(jù)數(shù)據(jù)綁定需要哪些知識點 數(shù)據(jù)劫持 發(fā)布訂閱模式 ...

    anonymoussf 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<