国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

淺談JS如何實現真正的對象常量

2019-11-19 16:15:32
字體:
來源:轉載
供稿:網友

前言

眾所周知ES6新增的const關鍵字可以用來聲明常量,但是它只對基本數據類型生效(Number、String、Boolean等),那如果我們想聲明一個常量對象呢?該如何實現,Object內置對象早就替我們想到了,下面來具體看一下

正題

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

代碼:

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

運行結果:


可以看到,控制臺報錯了,所以基本類型常量一旦聲明復制,就不能在被修改

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

代碼:

const Obj = {   name: 'jack'}Obj.name = 'lucy' // 修改屬性Obj.age = 23 // 擴展屬性console.log(Obj.name)console.log(Obj.age)delete Obj.ageconsole.log(Obj.age) // 刪除屬性Obj = {   name: 'sam'}

運行結果:

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

要想得到一個真正的對象常量,我們無非要做的就是以下三點:

1.對象的屬性不得被擴展

2.對象的屬性不得被刪除
3.對象的屬性不得被修改

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

代碼:

var Obj = {   name: 'jack'}Object.preventExtensions(Obj)Obj.age = 23 // 擴展屬性console.log(Obj.age) // undefined(說明擴展失敗了)

運行結果:

(2) 接著,擴展的問題解決了,那如何實現屬性不會被刪除呢?不必擔心,我們有Object.seal方法,該方法不僅可以保證對象的屬性不會被擴展,而且還能防止屬性被刪除

代碼:

var Obj = {   name: 'jack'}Object.seal(Obj)Obj.age = 23 // 擴展屬性console.log(Obj.age) // undefined(說明擴展失敗了)delete Obj.name // 刪除屬性console.log(Obj.name) // 'jack'(說明刪除失敗了)

運行結果:

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

代碼:

var Obj = {   name: 'jack'}Object.freeze(Obj)Obj.age = 23 // 擴展屬性console.log(Obj.age) // undefined(說明擴展失敗了)delete Obj.name // 刪除屬性console.log(Obj.name) // 'jack'(說明刪除失敗了)Obj.name = 'lucy' // 修改屬性console.log(Obj.name) // 'jack'(說明修改失敗)

運行截圖:

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


以上就是一步步的演示如何實現一個真正的對象常量,但是有如下兩個問題:

1.如果我們調用了這三個方法中的任何一個,然后我們再去做它們所禁止的行為(preventExtensions禁止擴展屬性,seal禁止刪除屬性,freeze禁止修改屬性),那么,如果在嚴格模式下,程序會報錯,所以我們要謹慎使用

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

代碼:

var Obj = {   name: 'jack',   extraInfo: {     age: 23   }}Object.freeze(Obj)Obj.extraInfo.age = 80console.log(Obj.extraInfo.age)  // 80

運行截圖:

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

// constantize實現遞歸freezevar 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 = 80console.log(Obj.extraInfo.age)  // 23

結語

以上就是常量對象的一些知識點,日常開發中,我們可以引入對象常量這個概念,來配置默認參數對象或一些配置信息,使我們的代碼更加嚴謹

這篇淺談JS如何實現真正的對象常量就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 井冈山市| 温州市| 长宁县| 孝感市| 进贤县| 桦川县| 资溪县| 许昌县| 两当县| 区。| 绥化市| 华安县| 资兴市| 新竹市| 邵阳县| 泸州市| 象州县| 晋宁县| 牟定县| 柳江县| 广宁县| 巴东县| 介休市| 邵东县| 沿河| 奉节县| 礼泉县| 南阳市| 新郑市| 石渠县| 浦北县| 咸丰县| 枞阳县| 绥芬河市| 梧州市| 彭山县| 北安市| 舞阳县| 喜德县| 赤峰市| 时尚|