Javascript中的對象屬性是有序的嗎
前言
最近有人問我,JavaScript對象屬性是否一定是無序的、不可預(yù)測的?
早期接觸過JavaScript的開發(fā)者可能會回答,??Object.keys()?
?或??for...in?
?會返回一個不可預(yù)知的對象屬性順序。
但現(xiàn)在的情況仍然是這樣嗎?
不是了,有些情況下是有序的。
從ECMAScript 2020開始,??Object.key?
??、??for...in?
??、??Object.getOwnPropertyNames?
??和??Reflect.ownKeys?
?都遵循同一個規(guī)范順序。它們是:
自己的屬性是數(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?
? 中。
自身的 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)。
到此這篇關(guān)于Javascript中的對象屬性是有序的嗎的文章就介紹到這了,更多相關(guān)Javascript對象屬性內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實(shí)現(xiàn)鼠標(biāo)滑過文字鏈接色彩變化的效果
這篇文章主要介紹了js實(shí)現(xiàn)鼠標(biāo)滑過文字鏈接色彩變化的效果,涉及javascript鼠標(biāo)事件及樣式操作的技巧,非常具有實(shí)用價值,需要的朋友可以參考下2015-05-05JavaScript實(shí)現(xiàn)列出數(shù)組中最長的連續(xù)數(shù)
這篇文章主要介紹了JavaScript實(shí)現(xiàn)列出數(shù)組中最長的連續(xù)數(shù)的方法及使用,需要的朋友可以參考下2014-12-12js中數(shù)組結(jié)合字符串實(shí)現(xiàn)查找(屏蔽廣告判斷url等)
這篇文章主要介紹了js中數(shù)組結(jié)合字符串實(shí)現(xiàn)查找(屏蔽廣告判斷url等),需要的朋友可以參考下2016-03-03關(guān)于javascript解決閉包漏洞的一個問題詳解
閉包在JavaScript高級程序設(shè)計(第3版)中是這樣描述:閉包是指有權(quán)訪問另一個函數(shù)作用域中的變量的函數(shù),下面這篇文章主要給大家介紹了關(guān)于javascript解決閉包漏洞的一個問題的相關(guān)資料,需要的朋友可以參考下2022-11-11網(wǎng)絡(luò)圖片延遲加載實(shí)現(xiàn)代碼 超越j(luò)query控件
原理是分段加載圖片,主要用于大型網(wǎng)站節(jié)省帶寬,可是他們提供的東西壓縮混淆看不清,還有的要基于什么雅虎的什么庫,總之是很麻煩的,JQ的控件倒是夠清晰了,只是還是沒有達(dá)到節(jié)省網(wǎng)絡(luò)帶寬的效果2010-03-03父節(jié)點(diǎn)獲取子節(jié)點(diǎn)的字符串示例代碼
這篇文章主要介紹了父節(jié)點(diǎn)獲取子節(jié)點(diǎn)的字符串的方法,需要的朋友可以參考下2014-02-02JavaScript簡單實(shí)現(xiàn)鼠標(biāo)拖動選擇功能
本篇文章主要是對JavaScript簡單實(shí)現(xiàn)鼠標(biāo)拖動選擇功能的示例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-03-03antd組件Upload實(shí)現(xiàn)自己上傳的實(shí)現(xiàn)示例
這篇文章主要介紹了antd組件Upload實(shí)現(xiàn)自己上傳的實(shí)現(xiàn)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12用javascript實(shí)現(xiàn)gb2312轉(zhuǎn)utf-8的腳本
用javascript實(shí)現(xiàn)gb2312轉(zhuǎn)utf-8的腳本...2007-05-05