有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。

最近有人问我,JavaScript对象属性是否肯定是无序的、不可预测的?

晚期接触过JavaScript的开发者可能会答复,Object.keys()for...in会返回一个不可预知的对象属性程序。

但当初的状况依然是这样吗?

不是了,有些状况下是有序的。

从ECMAScript 2020开始,Object.keyfor...inObject.getOwnPropertyNamesReflect.ownKeys都遵循同一个标准程序。它们是:

1. 本人的属性是数组的索引,按数字索引升序排列

const obj = {  100: 100,  '2': 2,  12: 12,  '0': 0}// 上面打印的后果程序都是 ['0', '2', '12', '100']console.log(Object.keys(obj))console.log(Object.getOwnPropertyNames(obj))console.log(Reflect.ownKeys(obj))for (const key in obj) {  console.log('key', key)}
const obj = {  a: 'a',};obj.b = 'b';setTimeout(() => {  obj.c = 'c';});obj.d = 'd';// 上面打印的后果程序都是 `[ 'a', 'b', 'd' ]`console.log(Object.keys(obj));console.log(Object.getOwnPropertyNames(obj));console.log(Reflect.ownKeys(obj));for (const key in obj) {  console.log('key: ', key);}

下面的代码增加了事件循环的知识点。因为 setTimeout 是一个异步的宏工作,当console.log输入时,c属性还没有被增加到 obj 中。

3. 本身的 Symbol 属性,按创立工夫程序递增

const obj = {  [Symbol('a')]: 'a',  [Symbol.for('b')]: 'b',};obj[Symbol('c')] = 'c';console.log(Object.keys(obj)); // []console.log(Object.getOwnPropertyNames(obj)); // []console.log(Reflect.ownKeys(obj)); // [ Symbol(a), Symbol(b), Symbol(c) ]for (const key in obj) {  console.log('key: ', key); // 没有输入}console.log(Object.getOwnPropertySymbols(obj)); // [ Symbol(a), Symbol(b), Symbol(c) ]

Symbol 属性和 String 属性一样,是依照属性创立的工夫程序升序排列的。然而Object.key, for...in, Object.getOwnPropertyNames办法不能取得对象的 Symbol 属性,Reflect.ownKeysObject.getOwnPropertySymbols 能够。

总结

当一个对象的属性键是上述类型的组合时,该对象的非负整数键(可枚举和不可枚举)首先按升序增加到数组中,而后按插入程序增加字符串键。最初,Symbol 键按插入程序退出。

const obj = {  100: 100,  0: 0,  a: 'a',  [Symbol('a')]: 'a',};obj[Symbol.for('b')] = 'b';obj.b = 'b';console.log(Object.keys(obj)); // [ '0', '100', 'a', 'b' ]console.log(Object.getOwnPropertyNames(obj)); // [ '0', '100', 'a', 'b' ]console.log(Reflect.ownKeys(obj)); // [ '0', '100', 'a', 'b', Symbol(a), Symbol(b) ]for (const key in obj) {  console.log('key: ', key); // '0' '100' 'a' 'b'}console.log(Object.getOwnPropertySymbols(obj)); // [ Symbol(a), Symbol(b) ]

然而,如果你强烈依赖插入程序,那么Map能够保障这一点。


编辑中可能存在的bug没法实时晓得,预先为了解决这些bug,花了大量的工夫进行log 调试,这边顺便给大家举荐一个好用的BUG监控工具 Fundebug。

作者:islizeqiang 译者:小智 起源:medium

原文:https://medium.com/@islizeqia...

交换

有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。

本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。