浅谈JS如何实现真正的对象常量

发布时间 - 2026-01-11 02:02:50    点击率:

前言

众所周知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.age
console.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 = 80
console.log(Obj.extraInfo.age)  // 80

运行截图:

所以要想真正实现常量对象,我们需要以树的形式把对象的子孙对象都freeze,Object.freeze和递归可以解决该问题

// constantize实现递归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

结语

以上就是常量对象的一些知识点,日常开发中,我们可以引入对象常量这个概念,来配置默认参数对象或一些配置信息,使我们的代码更加严谨

这篇浅谈JS如何实现真正的对象常量就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# js对象常量  # 详解JavaScript常量定义  # JS 创建对象(常见的几种方法)  # JavaScript 三种创建对象的方法  # js创建对象的方法汇总  # js中创建对象的几种方式  # 递归  # 失败了  # 如何实现  # 要想  # 给大家  # 看一下  # 这一  # 就不  # 还能  # 可以用  # 能在  # 我们可以  # 错了  # 希望能  # 要做  # 再来  # 可以看到  # 使我  # 它可以  # 任何一个 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  如何在服务器上三步完成建站并提升流量?  如何制作一个表白网站视频,关于勇敢表白的小标题?  如何选择PHP开源工具快速搭建网站?  Laravel如何使用Livewire构建动态组件?(入门代码)  phpredis提高消息队列的实时性方法(推荐)  成都网站制作公司哪家好,四川省职工服务网是做什么用?  iOS UIView常见属性方法小结  米侠浏览器网页背景异常怎么办 米侠显示修复  个人网站制作流程图片大全,个人网站如何注销?  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  Laravel如何实现模型的全局作用域?(Global Scope示例)  详解jQuery停止动画——stop()方法的使用  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  如何在Tomcat中配置并部署网站项目?  Python文本处理实践_日志清洗解析【指导】  js代码实现下拉菜单【推荐】  大学网站设计制作软件有哪些,如何将网站制作成自己app?  如何用JavaScript实现文本编辑器_光标和选区怎么处理  如何在建站主机中优化服务器配置?  JavaScript实现Fly Bird小游戏  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  昵图网官方站入口 昵图网素材图库官网入口  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  javascript中对象的定义、使用以及对象和原型链操作小结  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  5种Android数据存储方式汇总  进行网站优化必须要坚持的四大原则  php json中文编码为null的解决办法  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  Laravel如何配置中间件Middleware_Laravel自定义中间件拦截请求与权限校验【步骤】  微信小程序 闭包写法详细介绍  Laravel怎么实现一对多关联查询_Laravel Eloquent模型关系定义与预加载【实战】  Laravel怎么配置S3云存储驱动_Laravel集成阿里云OSS或AWS S3存储桶【教程】  Laravel如何从数据库删除数据_Laravel destroy和delete方法区别  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  香港服务器网站推广:SEO优化与外贸独立站搭建策略  北京企业网站设计制作公司,北京铁路集团官方网站?  如何在IIS中新建站点并配置端口与IP地址?  大同网页,大同瑞慈医院官网?  Laravel PHP版本要求一览_Laravel各版本环境要求对照  Laravel怎么设置路由分组Prefix_Laravel多级路由嵌套与命名空间隔离【步骤】  详解Android中Activity的四大启动模式实验简述  Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  香港服务器网站卡顿?如何解决网络延迟与负载问题?  ChatGPT 4.0官网入口地址 ChatGPT在线体验官网  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  如何用PHP工具快速搭建高效网站?