javascript
JS面向对象——Object.defineProperty
一、JavaScript的面向?qū)ο?/h2>
JavaScript其實(shí)支持多種編程范式的,包括函數(shù)式編程和面向?qū)ο缶幊?#xff1a;
- JavaScript中的對(duì)象被設(shè)計(jì)成一組屬性的無(wú)序集合,像是一個(gè)哈希表,有key和value組成;
- key是一個(gè)標(biāo)識(shí)符名稱,value可以是任意類型,也可以是其他對(duì)象或者函數(shù)類型;
- 如果值是一個(gè)函數(shù),那么我們可以稱之為是對(duì)象的方法;
如何創(chuàng)建一個(gè)對(duì)象呢?
早期使用創(chuàng)建對(duì)象的方式最多的是使用Object類,并且使用new關(guān)鍵字來(lái)創(chuàng)建一個(gè)對(duì)象:
- 這是因?yàn)樵缙诤芏郕avaScript開(kāi)發(fā)者是從Java過(guò)來(lái)的,它們也更習(xí)慣于Java中通過(guò)new的方式創(chuàng)建一個(gè)對(duì)象;
后來(lái)很多開(kāi)發(fā)者為了方便起見(jiàn),都是直接通過(guò)字面量的形式來(lái)創(chuàng)建對(duì)象:
- 這種形式看起來(lái)更加的簡(jiǎn)潔,并且對(duì)象和屬性之間的內(nèi)聚性也更強(qiáng),所以這種方式后來(lái)就流行了起來(lái);
二、對(duì)屬性操作的控制
在前面我們的屬性都是直接定義在對(duì)象內(nèi)部,或者直接添加到對(duì)象內(nèi)部的:
- 但是這樣來(lái)做的時(shí)候我們就不能對(duì)這個(gè)屬性進(jìn)行一些限制:比如這個(gè)屬性是否是可以通過(guò)delete刪除呢?這個(gè)屬性是否在for-in遍歷的時(shí)候被遍歷出來(lái)呢?
如果我們想要對(duì)一個(gè)屬性進(jìn)行比較精準(zhǔn)的操作控制,那么我們就可以使用屬性描述符。
- 通過(guò)屬性描述符可以精準(zhǔn)的添加或修改對(duì)象的屬性;
- 屬性描述符需要使用 Object.defineProperty 來(lái)對(duì)屬性進(jìn)行添加或者修改;
三、Object.defineProperty
Object.defineProperty() 方法會(huì)直接在一個(gè)對(duì)象上定義一個(gè)新屬性,或者修改一個(gè)對(duì)象的現(xiàn)有屬性,并返回此對(duì)象。
可接收三個(gè)參數(shù):
- obj要定義屬性的對(duì)象;
- prop要定義或修改的屬性的名稱或 Symbol;
- descriptor要定義或修改的屬性描述符;
返回值:
- 被傳遞給函數(shù)的對(duì)象。
四、屬性描述符分類
屬性描述符的類型有兩種:
- 數(shù)據(jù)屬性(Data Properties)描述符(Descriptor);
- 存取屬性(Accessor訪問(wèn)器 Properties)描述符(Descriptor);
五、數(shù)據(jù)屬性描述符
六、存取屬性描述符
七、同時(shí)定義多個(gè)屬性
Object.defineProperties() 方法直接在一個(gè)對(duì)象上定義 多個(gè) 新的屬性或修改現(xiàn)有屬性,并且返回該對(duì)象。
八、對(duì)象方法補(bǔ)充
獲取對(duì)象的屬性描述符:
- getOwnPropertyDescriptor
- getOwnPropertyDescriptors
禁止對(duì)象擴(kuò)展新屬性:preventExtensions
- 給一個(gè)對(duì)象添加新的屬性會(huì)失敗(在嚴(yán)格模式下會(huì)報(bào)錯(cuò));
密封對(duì)象,不允許配置和刪除屬性:seal
- 實(shí)際是調(diào)用preventExtensions
- 并且將現(xiàn)有屬性的configurable:false
凍結(jié)對(duì)象,不允許修改現(xiàn)有屬性: freeze
- 實(shí)際上是調(diào)用seal
- 并且將現(xiàn)有屬性的writable: false
總結(jié)
以上是生活随笔為你收集整理的JS面向对象——Object.defineProperty的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Express框架实现原理
- 下一篇: gradle idea java ssm