热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ES5对象的扩展(Object.preventExtensions)、密封(Object.seal)和冻结(Object.freeze)

前面提到ES5对象属性描述符,这篇看看对象的扩展、密封和冻结。扩展对象Object.preventExtensionsObject.isExtensible密封对象Object.sealObjec

前面提到 ES5 对象属性描述符,这篇看看对象的扩展、密封和冻结。

  1. 扩展对象
    1. Object.preventExtensions
    2. Object.isExtensible
  2. 密封对象
    1. Object.seal
    2. Object.isSealed
  3. 冻结对象
    1. Object.freeze
    2. Object.isFrozen

 

1. Object.preventExtensions

阻止对象扩展,让一个对象变的不可扩展,也就是永远不能再添加新的属性

 

ES3 是没有办法阻止对象扩展的,定义对象后可以给对象添加任意属性,如

var obj = {name: 'John'}

// 又添加一个属性 age
obj.age = 30

// 又添加一个方法
obj.setAge = function(a) {
this.age = a
}

 

ES5 的 Object.preventExtensions 则可以阻止给对象添加新属性

var obj = {name: 'John'}

// 阻止对象扩展
Object.preventExtensions(obj)

// 添加新属性
obj.age = 30

// 测试新属性,是 undefined,表明未添加成功
console.log(obj.age)

 

如果严格模式,则会报错

'use strict'
var obj = {name: 'John'}
Object.preventExtensions(obj)
obj.age = 30

如图

 

2. Object.isExtensible

判断一个对象是否可扩展,即是否可以给它添加新属性

 

默认普通对象都是可以扩展的,这和 ES3 保持一致

var obj = {}

// true,表示可扩展
Object.isExtensible(obj)

 

但调用 ES5 的 Object.preventExtensions 后就返回 false 了

var obj = {}
Object.preventExtensions(obj)

// false,表示不可添加新属性
Object.isExtensible(obj)

 

3. Object.seal

让一个对象密封,并返回被密封后的对象。密封对象是指那些不能添加新的属性,不能删除已有属性,以及不能修改已有属性的可枚举性、可配置性、可写性,但可以修改已有属性的值的对象。

 

测试:添加新属性

var obj = {name: 'John'}

// 密封
Object.seal(obj)

// 不能添加新属性
obj.age = 30
console.log(obj.age) // undefined

 

测试:删除已有属性

var obj = {name: 'John'}

// 密封
Object.seal(obj)

// 不能删除已有属性
delete obj.name // false
console.log(obj.name) // 'John',依然存在

 

测试:修改已有属性的可枚举性、可配置性、可写性

var obj = {name: 'John'}

// 密封
Object.seal(obj)

// 修改已有的配置属性
Object.defineProperty(obj, 'name', {
configurable: true,
writable: true,
enumerable: true
})

浏览器提示报错

 

测试:修改已有属性的值

var obj = {name: 'John'}

// 密封
Object.seal(obj)

// 可以修改已有属性的值
obj.name = 'Backus'
console.log(obj.name) // 'Backus'

  

4. Object.isSealed

判断一个对象是否是密封的(sealed)

 

普通对象是非密封的,和 ES3 保持一致

var obj = {}
Object.isSealed(obj) // false

 

调用 Object.seal 的对象是密封的

var obj = {}
Object.seal(obj)
Object.isSealed(obj) // true

 

5. Object.freeze

这个方法比 Object.seal 更绝,冻结对象是指那些不能添加新的属性,不能修改已有属性的值,不能删除已有属性,以及不能修改已有属性的可枚举性、可配置性、可写性的对象。也就是说,这个对象永远是不可变的。

 

测试:添加新属性

var obj = {name: 'John'}
Object.freeze(obj)
obj.age = 30
console.log(obj.age) // undefined

不能添加 age 属性,表明被冻结的对象不能添加新属性。如果是严格模式则报错,如图

 

测试:修改已有属性

var obj = {name: 'John'}
Object.freeze(obj)
obj.name = 'Backus'
console.log(obj.name) // 'John'

想修改为 "Backus",输出依然是 "John",表明不能修改已有属性。如果是严格模式则报错,如图

 

测试:删除已有属性

var obj = {name: 'John'}
Object.freeze(obj)
delete obj.name
console.log(obj.name) // 'John'

想删除 "name" 属性,输出依然是 "John",表明不能删除已有属性。如果是严格模式则报错,如图

 

测试:修改已有属性的可枚举性、可配置性、可写性

var obj = {name: 'John'}
Object.freeze(obj)
Object.defineProperty(obj, 'name', {
configurable: true,
writable: true,
enumerable: true
})

这个在非严格模式中就报错了,表明 configurable/writable/enmuerable 不能修改,如图

 

6. Object.isFrozen

判断一个对象是否被冻结(frozen)

 

普通对象是非冻结的,和 ES3 保持一致

var obj = {name: 'John'}
Object.isFrozen(obj) // false

 

调用 Object.freeze 的对象是冻结的

var obj = {name: 'John'}
Object.freeze(obj)
Object.isFrozen(obj) // true

  

 


推荐阅读
  • 文章目录前言Program(程序)Identifier(标识符)Literal(字面量)Vari ... [详细]
  • 使用C#构建动态图形界面时钟
    本篇文章将详细介绍如何利用C#语言开发一个具有动态显示功能的图形界面时钟。文章中不仅提供了详细的代码示例,还对可能出现的问题进行了深入分析,并给出了解决方案。 ... [详细]
  • 协程作为一种并发设计模式,能有效简化Android平台上的异步代码处理。自Kotlin 1.3版本引入协程以来,这一特性基于其他语言的成熟理念,为开发者提供了新的工具,以增强应用的响应性和效率。 ... [详细]
  • RTThread线程间通信
    线程中通信在裸机编程中,经常会使用全局变量进行功能间的通信,如某些功能可能由于一些操作而改变全局变量的值,另一个功能对此全局变量进行读取& ... [详细]
  • C# 实现高效分页控件
    在使用 C# 进行数据库开发时,分页功能是常见的需求。为了避免每次编写重复的分页代码,我开发了一个用户控件,使分页操作变得更加简便。 ... [详细]
  • 本文详细介绍了如何在循环双链表的指定位置插入新元素的方法,包括必要的步骤和代码示例。 ... [详细]
  • 使用QT构建基础串口辅助工具
    本文详细介绍了如何利用QT框架创建一个简易的串口助手应用程序,包括项目的建立、界面设计与编程实现、运行测试以及最终的应用程序打包。 ... [详细]
  • 本文介绍了一个使用Spring框架和Quartz调度器实现每周定时调用Web服务获取数据的小项目。通过详细配置Spring XML文件,展示了如何设置定时任务以及解决可能遇到的自动注入问题。 ... [详细]
  • 使用 jQuery 实现页面加载进度条
    页面加载进度条是提升用户体验的重要工具,通过在页面头部显示一个加载状态,并在页面完全加载后隐藏,可以有效减少用户的等待焦虑。本文将详细介绍如何使用 jQuery 实现这一功能。 ... [详细]
  • 在现代Web开发中,HTML5 Canvas常用于图像处理和绘图任务。本文将详细介绍如何将Canvas中的图像导出并上传至服务器,适用于拼图、图片编辑等场景。 ... [详细]
  • 本文将探讨如何在 Struts2 中使用 ActionContext 和 ServletActionContext 来获取请求参数和会话信息,同时解释它们的内部机制和最佳实践。 ... [详细]
  • php三角形面积,335宝石大全
    php三角形面积,335宝石大全 ... [详细]
  • 本文介绍了GitHub上的一些Python开源项目,特别是IM(即时通讯)技术的应用。通过Sealtalk项目,探讨了如何利用开源SDK提升开发效率。 ... [详细]
  • 深入解析Dubbo:使用与源码分析
    本文详细介绍了Dubbo的使用方法和源码分析,涵盖其架构设计、核心特性和调用流程。 ... [详细]
  • 本文通过一个简单的示例,详细介绍了如何在 C# 中使用 yield return 和 yield break 关键字来实现延迟迭代和提前终止循环的功能。希望对你的开发工作有所帮助。 ... [详细]
author-avatar
Angkaka
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有