成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面試官:JavaScript對象屬性是有序的嗎?

開發(fā) 前端
當(dāng)一個(gè)對象的屬性鍵是上述類型的組合時(shí),該對象的非負(fù)整數(shù)鍵(可枚舉和不可枚舉)首先按升序添加到數(shù)組中,然后按插入順序添加字符串鍵。最后,Symbol 鍵按插入順序加入。

最近有人問我,JavaScript對象屬性是否一定是無序的、不可預(yù)測的?

早期接觸過JavaScript的開發(fā)者可能會回答,Object.keys()for...in會返回一個(gè)不可預(yù)知的對象屬性順序。

但現(xiàn)在的情況仍然是這樣嗎?

不是了,有些情況下是有序的。

從ECMAScript 2020開始,Object.keyfor...inObject.getOwnPropertyNamesReflect.ownKeys都遵循同一個(gè)規(guī)范順序。它們是:

1. 自己的屬性是數(shù)組的索引,按數(shù)字索引升序排列

const obj = {
100: 100,
'2': 2,
12: 12,
'0': 0
}
// 下面打印的結(jié)果順序都是 ['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';

// 下面打印的結(jié)果順序都是 `[ '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);
}

上面的代碼添加了事件循環(huán)的知識點(diǎn)。因?yàn)?nbsp;setTimeout 是一個(gè)異步的宏任務(wù),當(dāng)console.log輸出時(shí),c屬性還沒有被添加到 obj 中。

2. 自身的 Symbol 屬性,按創(chuàng)建時(shí)間順序遞增

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 屬性一樣,是按照屬性創(chuàng)建的時(shí)間順序升序排列的。但是Object.keyfor...in,Object.getOwnPropertyNames方法不能獲得對象的 Symbol 屬性,Reflect.ownKeysObject.getOwnPropertySymbols 可以。

總結(jié)

當(dāng)一個(gè)對象的屬性鍵是上述類型的組合時(shí),該對象的非負(fù)整數(shù)鍵(可枚舉和不可枚舉)首先按升序添加到數(shù)組中,然后按插入順序添加字符串鍵。最后,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) ]

但是,如果你強(qiáng)烈依賴插入順序,那么Map可以保證這一點(diǎn)。

作者:islizeqiang

譯者:小智

來源:medium

原文:https://medium.com/@
islizeqiang/are-javascript-object-properties-ordered-c30597754e5c

責(zé)任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2023-11-27 08:32:02

元素HashMap

2022-02-08 08:14:07

Context數(shù)據(jù)線程

2023-08-11 17:13:39

JavaScrip

2021-09-07 10:44:33

Java 注解開發(fā)

2023-08-13 16:17:31

2021-02-19 10:02:57

HTTPSJava安全

2024-02-04 10:08:34

2020-03-10 08:01:05

Java堆內(nèi)存線程共享

2022-07-18 13:59:43

Redis單線程進(jìn)程

2024-12-25 15:44:15

2024-02-22 15:36:23

Java內(nèi)存模型線程

2021-12-08 06:53:29

面試動態(tài)代理

2024-11-26 17:43:51

2024-06-04 09:02:03

2022-09-29 07:30:57

數(shù)據(jù)庫索引字段

2024-05-11 15:11:44

系統(tǒng)軟件部署

2015-08-13 10:29:12

面試面試官

2021-05-20 08:54:16

Go面向對象

2022-07-26 08:40:42

Java并發(fā)工具類

2022-08-02 06:31:32

Java并發(fā)工具類
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产在线观看一区二区三区 | 久久福利电影 | 91免费在线| 操夜夜| 欧美成人影院 | 国产精品不卡 | 国产午夜精品一区二区三区在线观看 | 国产精品久久久久久久久久久久 | 美国黄色一级片 | 在线播放精品视频 | 一级毛片视频 | 日本成人久久 | 激情五月综合网 | 国产一区二区三区在线免费观看 | 亚洲九九精品 | 亚洲三区在线播放 | 国产ts人妖一区二区三区 | 91中文在线观看 | 欧美精品一区二区在线观看 | 国产九一精品 | www4虎 | 一级黄色片美国 | 91久久综合亚洲鲁鲁五月天 | 欧美一级片免费看 | 天堂av中文在线 | 精品欧美一区二区三区久久久 | 欧美最猛性xxxxx亚洲精品 | 久久久久久国 | 久久日韩粉嫩一区二区三区 | 久久午夜视频 | 欧美日韩一区二区视频在线观看 | 日韩中文字幕网 | 色综合天天综合网国产成人网 | 欧美日韩一区二区三区在线观看 | 在线看h| 亚洲视频免费 | 一级做a爰片久久毛片免费看 | 亚洲日本欧美日韩高观看 | chengrenzaixian | 国产成人综合在线 | 蜜臀网站 |