溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JS怎么實(shí)現(xiàn)對(duì)象常量

發(fā)布時(shí)間:2021-02-22 10:23:26 來源:億速云 閱讀:228 作者:小新 欄目:web開發(fā)

這篇文章給大家分享的是有關(guān)JS怎么實(shí)現(xiàn)對(duì)象常量的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

前言

眾所周知ES6新增的const關(guān)鍵字可以用來聲明常量,但是它只對(duì)基本數(shù)據(jù)類型生效(Number、String、Boolean等),那如果我們想聲明一個(gè)常量對(duì)象呢?該如何實(shí)現(xiàn)?

正題

一、先來看一下const方式來聲明基本類型常量

代碼:

 const name = 'jack'
 name = 'lucy'  // 修改name常量

運(yùn)行結(jié)果:

JS怎么實(shí)現(xiàn)對(duì)象常量


可以看到,控制臺(tái)報(bào)錯(cuò)了,所以基本類型常量一旦聲明復(fù)制,就不能在被修改

二、再來用const方式來聲明復(fù)雜類型常量(即對(duì)象常量)

代碼:

const Obj = {
   name: 'jack'
}

Obj.name = 'lucy' // 修改屬性
Obj.age = 23 // 擴(kuò)展屬性
console.log(Obj.name)
console.log(Obj.age)

delete Obj.age
console.log(Obj.age) // 刪除屬性

Obj = {
   name: 'sam'
}

運(yùn)行結(jié)果:

JS怎么實(shí)現(xiàn)對(duì)象常量

結(jié)果表明:對(duì)象常量只是不允許修改引用地址,但是屬性還是可以被修改、擴(kuò)展和刪除的

要想得到一個(gè)真正的對(duì)象常量,我們無非要做的就是以下三點(diǎn):

1.對(duì)象的屬性不得被擴(kuò)展

2.對(duì)象的屬性不得被刪除
3.對(duì)象的屬性不得被修改

(1) 首先,如何做的對(duì)象屬性不會(huì)被擴(kuò)展呢?我們可以用Object.preventExtensions方法做到這一點(diǎn)

代碼:

var Obj = {
   name: 'jack'
}

Object.preventExtensions(Obj)

Obj.age = 23 // 擴(kuò)展屬性
console.log(Obj.age) // undefined(說明擴(kuò)展失敗了)

運(yùn)行結(jié)果:

JS怎么實(shí)現(xiàn)對(duì)象常量

(2) 接著,擴(kuò)展的問題解決了,那如何實(shí)現(xiàn)屬性不會(huì)被刪除呢?不必?fù)?dān)心,我們有Object.seal方法,該方法不僅可以保證對(duì)象的屬性不會(huì)被擴(kuò)展,而且還能防止屬性被刪除

代碼:

var Obj = {
   name: 'jack'
}

Object.seal(Obj)

Obj.age = 23 // 擴(kuò)展屬性
console.log(Obj.age) // undefined(說明擴(kuò)展失敗了)

delete Obj.name // 刪除屬性
console.log(Obj.name) // 'jack'(說明刪除失敗了)

運(yùn)行結(jié)果:

JS怎么實(shí)現(xiàn)對(duì)象常量

(3) 擴(kuò)展和刪除的問題都已經(jīng)得到了解決,就剩下屬性不得被修改的問題了,那么我們清楚終極Boss:Object.freeze,它可以做的對(duì)象既不可被擴(kuò)展和刪除,而且還不被修改

代碼:

var Obj = {
   name: 'jack'
}

Object.freeze(Obj)

Obj.age = 23 // 擴(kuò)展屬性
console.log(Obj.age) // undefined(說明擴(kuò)展失敗了)

delete Obj.name // 刪除屬性
console.log(Obj.name) // 'jack'(說明刪除失敗了)

Obj.name = 'lucy' // 修改屬性
console.log(Obj.name) // 'jack'(說明修改失敗)

運(yùn)行截圖:

JS怎么實(shí)現(xiàn)對(duì)象常量

/***************************分割線*******************************/


以上就是一步步的演示如何實(shí)現(xiàn)一個(gè)真正的對(duì)象常量,但是有如下兩個(gè)問題:

1.如果我們調(diào)用了這三個(gè)方法中的任何一個(gè),然后我們?cè)偃プ鏊鼈兯沟男袨椋╬reventExtensions禁止擴(kuò)展屬性,seal禁止刪除屬性,freeze禁止修改屬性),那么,如果在嚴(yán)格模式下,程序會(huì)報(bào)錯(cuò),所以我們要謹(jǐn)慎使用

2.Object.freeze雖然實(shí)現(xiàn)了真正的對(duì)象常量,但是它的一切操作只在頂級(jí)對(duì)象屬性上生效,下面的代碼說明了這一問題

代碼:

var Obj = {
   name: 'jack',
   extraInfo: {
     age: 23
   }
}

Object.freeze(Obj)

Obj.extraInfo.age = 80
console.log(Obj.extraInfo.age)  // 80

運(yùn)行截圖:

JS怎么實(shí)現(xiàn)對(duì)象常量

所以要想真正實(shí)現(xiàn)常量對(duì)象,我們需要以樹的形式把對(duì)象的子孫對(duì)象都freeze,Object.freeze和遞歸可以解決該問題

// constantize實(shí)現(xiàn)遞歸freeze
var constantize = (obj) => {
   Object.freeze(obj);
   Object.keys(obj).forEach( (key, i) => {
      if ( typeof obj[key] === 'object' ) {
        constantize( obj[key] );
     }
   });
}

var Obj = {
   name: 'jack',
   extraInfo: {
      age: 23
   }
}

constantize(Obj)

Obj.extraInfo.age = 80
console.log(Obj.extraInfo.age)  // 23

感謝各位的閱讀!關(guān)于“JS怎么實(shí)現(xiàn)對(duì)象常量”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI