日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
面試官:JavaScript對(duì)象屬性是有序的嗎?

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

成都創(chuàng)新互聯(lián)公司專注于金塔網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供金塔營(yíng)銷型網(wǎng)站建設(shè),金塔網(wǎng)站制作、金塔網(wǎng)頁(yè)設(shè)計(jì)、金塔網(wǎng)站官網(wǎng)定制、微信小程序定制開(kāi)發(fā)服務(wù),打造金塔網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供金塔網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。

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

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

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

從ECMAScript 2020開(kāi)始,Object.key、for...in、Object.getOwnPropertyNames和Reflect.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)的知識(shí)點(diǎn)。因?yàn)?nbsp;setTimeout 是一個(gè)異步的宏任務(wù),當(dāng)console.log輸出時(shí),c屬性還沒(méi)有被添加到 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); // 沒(méi)有輸出
}

console.log(Object.getOwnPropertySymbols(obj)); // [ Symbol(a), Symbol(b), Symbol(c) ]

Symbol 屬性和 String 屬性一樣,是按照屬性創(chuàng)建的時(shí)間順序升序排列的。但是Object.key, for...in,Object.getOwnPropertyNames方法不能獲得對(duì)象的 Symbol 屬性,Reflect.ownKeys和Object.getOwnPropertySymbols 可以。

總結(jié)

當(dāng)一個(gè)對(duì)象的屬性鍵是上述類型的組合時(shí),該對(duì)象的非負(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

譯者:小智

來(lái)源:medium

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


本文標(biāo)題:面試官:JavaScript對(duì)象屬性是有序的嗎?
網(wǎng)站網(wǎng)址:http://m.5511xx.com/article/djsscie.html