共计 2178 个字符,预计需要花费 6 分钟才能阅读完成。
有幻想,有干货,微信搜寻 【大迁世界】 关注这个在凌晨还在刷碗的刷碗智。
本文 GitHub https://github.com/qq449245884/xiaozhi 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。
最近有人问我,JavaScript 对象属性是否肯定是无序的、不可预测的?
晚期接触过 JavaScript 的开发者可能会答复,Object.keys()
或 for...in
会返回一个不可预知的对象属性程序。
但当初的状况依然是这样吗?
不是了,有些状况下是有序的。
从 ECMAScript 2020 开始,Object.key
、for...in
、Object.getOwnPropertyNames
和 Reflect.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.ownKeys
和 Object.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 已收录,有一线大厂面试残缺考点、材料以及我的系列文章。