免费爱碰视频在线观看,九九精品国产屋,欧美亚洲尤物久久精品,1024在线观看视频亚洲

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

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

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

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

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

      從ECMAScript 2020開始,Object.key、for…in、Object.getOwnPropertyNames和Reflect.ownKeys都遵循同一個規(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)。因為 setTimeout 是一個異步的宏任務(wù),當(dāng)console.log輸出時,c屬性還沒有被添加到 obj 中。

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

      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)建的時間順序升序排列的。但是Object.key, for…in, Object.getOwnPropertyNames方法不能獲得對象的 Symbol 屬性,Reflect.ownKeys和 Object.getOwnPropertySymbols 可以。

      總結(jié)

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

      鄭重聲明:本文內(nèi)容及圖片均整理自互聯(lián)網(wǎng),不代表本站立場,版權(quán)歸原作者所有,如有侵權(quán)請聯(lián)系管理員(admin#wlmqw.com)刪除。
      用戶投稿
      上一篇 2022年7月15日 12:50
      下一篇 2022年7月15日 12:51

      相關(guān)推薦

      聯(lián)系我們

      聯(lián)系郵箱:admin#wlmqw.com
      工作時間:周一至周五,10:30-18:30,節(jié)假日休息