前面提到 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

  

ES5 对象的扩展(Object.preventExtensions)、密封(Object.seal)和冻结(Object.freeze)的更多相关文章

  1. ES6 的Object.assign(target, source_1, ···)方法与对象的扩展运算符

    一.基本概念 Object.assign方法用来将源对象(source)的所有可枚举属性,复制到目标对象(target).它至少需要两个对象作为参数,第一个参数是目标对象,后面的参数都是源对象. Ob ...

  2. ES6 对象的扩展 Object.assign()

    Object.assign方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target). const target = { a: 1 }; const source1 ...

  3. JS对象-不可扩展对象、密封对象、冻结对象

    不可扩展对象 Object.preventExtensions() 仅阻止添加自身的属性.但属性仍然可以添加到对象原型. 可以用 Object.isExtensible(obj) 来判断对象是否可扩展 ...

  4. ECMAScript5新特性之Object.isExtensible、Object.preventExtensions

    阻止对象扩展后: 1 不能添加属性. 2 可以修改属性的值. 3 可以删除属性. 4 可以修改属性描述符. var fruit = { name : '苹果', desc : '红富士' }; // ...

  5. Object.preventExtensions()使用技巧

    Object.preventExtensions() 方法让一个对象变的不可扩展,也就是永远不能再添加新的属性. // Object.preventExtensions将原对象变的不可扩展,并且返回原 ...

  6. ExtJS学习-----------Ext.Object,ExtJS对javascript中的Object的扩展

    关于ExtJS对javascript中的Object的扩展.能够參考其帮助文档,文档下载地址:http://download.csdn.net/detail/z1137730824/7748893 以 ...

  7. JavaScript原生对象及扩展

    来源于 https://segmentfault.com/a/1190000002634958 内置对象与原生对象 内置(Build-in)对象与原生(Naitve)对象的区别在于:前者总是在引擎初始 ...

  8. es6学习笔记--字符串&数值&数组&函数&对象的扩展

    这几天抽空学习了es6语法,关于字符串,数值,数组,函数以及对象的扩展,看到es6标准入门这本书,里面讲的扩展特别多,我认为有几部分在项目上用不到,就挑有用的当笔记学习了. 字符串的扩展 str.in ...

  9. ECMA Script 6_对象的扩展

    对象 1. ES6 允许直接写入变量和函数,作为对象的属性和方法 const foo = 'bar'; /*****************属性的优化********************/ con ...

随机推荐

  1. linux源码分析(四)-start_kernel-cgroup

    前置:这里使用的linux版本是4.8,x86体系. cgroup_init_early(); 聊这个函数就需要先了解cgroup. cgroup概念 这个函数就是初始化cgroup所需要的参数的.c ...

  2. mysql 日期函数总结

    1.0 格式化:DATE_FORMAT() 函数用于以不同的格式显示日期/时间数据. 语法 DATE_FORMAT(date,format) date 参数是合法的日期.format 规定日期/时间的 ...

  3. Android源码编译make的错误处理

    android源码下载:官方下载 或参考android源码下载方式 Android编译版本: PLATFORM_VERSION=4.0.1(最新Android 4.0.1) OS 操作系统平台: Li ...

  4. PHP工作笔记:数组转字符串与字符串转数组

    一个数组要入库,发现不可以,特定用函数转为字符串入库 $data = array( 'http://img4.bitautoimg.com/autoalbum/files/20110420/734/2 ...

  5. java-阻塞队列

    阻塞队列与普通队列的区别在于,当队列是空的时,从队列中获取元素的操作将会被阻塞,或者当队列是满时,往队列里添加元素的操作会被阻塞.试图从空的阻塞队列中获取元素的线程将会被阻塞,直到其他的线程往空的队列 ...

  6. [转]看部电影,透透彻彻理解IoC(你没有理由再迷惑!)

    之前对依赖注入的概念一直感到模糊,直到看了这篇文章:http://www.iteye.com/topic/1122835 引述: IoC(控制反转:Inverse of Control)是Spring ...

  7. 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用

    学习 EF Code First+MVC 时遇到了在请求JsonResult时出现 序列化类型 System.Data.Entity.DynamicProxies 的对象时检测到循环引用 的异常,原因 ...

  8. 高性能javascript学习笔记系列(5) -快速响应的用户界面和编程实践

    参考高性能javascript 理解浏览器UI线程  用于执行javascript和更新用户界面的进程通常被称为浏览器UI线程  UI线程的工作机制可以理解为一个简单的队列系统,队列中的任务按顺序执行 ...

  9. CSS属性简写

    盒模型简写: 如果top.right.bottom.left的值相同,如下面代码:margin:10px 10px 10px 10px; 缩写为:margin:10px; 如果top和bottom值相 ...

  10. mysql NOW,CURRENT_TIMESTAMP,SYSDATE 之间的区别

    这些函数都可以返回当前的系统时间,但它们之间有什么区别呢??大家先看一下以下这个例子. select NOW(), CURRENT_TIMESTAMP(),SYSDATE(); 从上面的例子可以看出返 ...