前言

众所周知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中创建对象的几种方式
# 递归
# 失败了
# 如何实现
# 要想
# 给大家
# 看一下
# 这一
# 就不
# 还能
# 可以用
# 能在
# 我们可以
# 错了
# 希望能
# 要做
# 再来
# 可以看到
# 使我
# 它可以
# 任何一个
相关文章:
建站主机如何安装配置?新手必看操作指南
如何在IIS中新建站点并解决端口绑定冲突?
如何选择最佳自助建站系统?快速指南解析优劣
如何快速登录WAP自助建站平台?
免费网站制作appp,免费制作app哪个平台好?
Python路径拼接规范_跨平台处理说明【指导】
如何快速搭建自助建站会员专属系统?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
建站主机选哪种环境更利于SEO优化?
建站之星北京办公室:智能建站系统与小程序生成方案解析
建站主机是否属于云主机类型?
C#如何使用XPathNavigator高效查询XML
如何在阿里云部署织梦网站?
如何挑选高效建站主机与优质域名?
如何通过FTP服务器快速搭建网站?
无锡营销型网站制作公司,无锡网选车牌流程?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
广州商城建站系统开发成本与周期如何控制?
C++如何编写函数模板?(泛型编程入门)
南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?
如何用虚拟主机快速搭建网站?详细步骤解析
如何快速配置高效服务器建站软件?
如何选择香港主机高效搭建外贸独立站?
设计网站制作公司有哪些,制作网页教程?
平台云上自助建站如何快速打造专业网站?
定制建站策划方案_专业建站与网站建设方案一站式指南
开心动漫网站制作软件下载,十分开心动画为何停播?
香港服务器网站推广:SEO优化与外贸独立站搭建策略
教学论文网站制作软件有哪些,写论文用什么软件
?
外贸公司网站制作哪家好,maersk船公司官网?
建站之星安装后如何自定义网站颜色与字体?
网站制作企业,网站的banner和导航栏是指什么?
建站之星如何助力企业快速打造五合一网站?
如何在橙子建站中快速调整背景颜色?
天津个人网站制作公司,天津网约车驾驶员从业资格证官网?
如何在阿里云虚拟主机上快速搭建个人网站?
如何用景安虚拟主机手机版绑定域名建站?
测试制作网站有哪些,测试性取向的权威测试或者网站?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
如何使用Golang安装API文档生成工具_快速生成接口文档
如何选择高效可靠的多用户建站源码资源?
建站之星2.7模板快速切换与批量管理功能操作指南
如何设计高效校园网站?
广德云建站网站建设方案与建站流程优化指南
建站之星安装提示数据库无法连接如何解决?
实现虚拟支付需哪些建站技术支撑?
大连网站制作公司哪家好一点,大连买房网站哪个好?
深圳网站制作的公司有哪些,dido官方网站?
如何快速搭建FTP站点实现文件共享?
如何配置支付宝与微信支付功能?
*请认真填写需求信息,我们会在24小时内与您取得联系。