ES6 对象的新增方法(十四)

1. Object.assign(target, ...sources)

特性 :将一个或多个源对象的所有可枚举属性复制到目标对象。
用法:用于对象属性的合并。

javascript 复制代码
const obj1 = { a: 1, b: 2 };
const obj2 = { b: 3, c: 4 };
Object.assign(obj1, obj2);

console.log(obj1); // 输出:{ a: 1, b: 3, c: 4 }

2. Object.keys(obj)

特性 :返回一个包含对象所有可枚举属性名称的数组。
用法:获取对象的所有键。

javascript 复制代码
const obj = { a: 1, b: 2, c: 3 };
console.log(Object.keys(obj)); // 输出:['a', 'b', 'c']

3. Object.values(obj)

特性 :返回一个包含对象所有可枚举属性值的数组。
用法:获取对象的所有值。

javascript 复制代码
const obj = { a: 1, b: 2, c: 3 };
console.log(Object.values(obj)); // 输出:[1, 2, 3]

4. Object.entries(obj)

特性 :返回一个给定对象自身可枚举属性的键值对数组。
用法:获取对象的键值对。

javascript 复制代码
const obj = { a: 1, b: 2, c: 3 };
console.log(Object.entries(obj)); // 输出:[ ['a', 1], ['b', 2], ['c', 3] ]

5. Object.isFrozen(obj)

特性 :判断对象是否被冻结,即不能添加新属性、删除现有属性或改变现有属性的可枚举性、可配置性、可写性。
用法:检查对象是否被冻结。

javascript 复制代码
const obj = {};
console.log(Object.isFrozen(obj)); // 输出:false

Object.freeze(obj);
console.log(Object.isFrozen(obj)); // 输出:true

6. Object.setPrototypeOf(obj, prototype)

特性 :设置对象的原型(内部[[Prototype]]属性)。
用法:改变对象的原型。

javascript 复制代码
const proto = {};
const obj = { a: 1 };
Object.setPrototypeOf(obj, proto);

console.log(Object.getPrototypeOf(obj) === proto); // 输出:true

7. Object.getPrototypeOf(obj)

特性 :获取对象的原型。
用法:读取对象的原型。

javascript 复制代码
const obj = Object.create({ a: 1 });
console.log(Object.getPrototypeOf(obj).a); // 输出:1

8. Object.preventExtensions(obj)

特性 :阻止添加新属性到对象。
用法:使对象不可扩展。

javascript 复制代码
const obj = { a: 1 };
Object.preventExtensions(obj);

obj.b = 2; // 不会添加属性 b
console.log(Object.keys(obj)); // 输出:['a']

9. Object.isExtensible(obj)

特性 :判断对象是否可扩展。
用法:检查对象是否可以添加新属性。

javascript 复制代码
const obj = {};
console.log(Object.isExtensible(obj)); // 输出:true

Object.preventExtensions(obj);
console.log(Object.isExtensible(obj)); // 输出:false

10. Object.getOwnPropertyDescriptors(obj)

特性 :返回一个对象的所有自身属性的描述符。
用法:获取对象属性的详细描述。

javascript 复制代码
const obj = { get a() { return 1; } };
console.log(Object.getOwnPropertyDescriptors(obj));
// 输出:{ a: { 
// get: [Function: get], 
// set: undefined, enumerable: false, 
// configurable: true 
// } }
相关推荐
小阿鑫10 小时前
32岁程序员猝死背后,我的一些真实感受
前端·后端·程序员·代码人生
qq_124987075310 小时前
基于Spring Boot的桶装水配送管理系统的设计与实现(源码+论文+部署+安装)
java·前端·spring boot·后端·spring·毕业设计·计算机毕业设计
Leweslyh10 小时前
【实战】如何在家定位国际空间站 (ISS)? —— 坐标转换的魔法 (例题 5.9)
开发语言·javascript·ecmascript
帆张芳显10 小时前
智表zcell产品V3.5 版发布,新增行列选中操作等功能
前端·javascript·excel·插件·canva可画
程序员小寒10 小时前
前端性能优化之首屏时间采集篇
前端·性能优化
GGGG寄了10 小时前
HTML——div和span标签和字符实体
前端·html
这儿有一堆花10 小时前
网页开发的基石:深入解析 HTML 与 PHP 的本质差异
前端·html·php
RFCEO10 小时前
网页编程 课程三、:HTML 核心规范(语义化+易维护)详解课程
前端·html·语义化·html核心规范·易维护·前端基础课
苦藤新鸡10 小时前
27.合并有序链表,串葫芦
前端·javascript·链表
_OP_CHEN10 小时前
【前端开发之HTML】(四)HTML 标签进阶:表格、表单、布局全掌握,从新手到实战高手!
前端·javascript·css·html·html5·网页开发·html标签