Javascript中的对象属性是有序的吗

 更新时间:2022年08月11日 15:06:27   作者:尼羲​​​​​​​  
这篇文章主要介绍了Javascript中的对象属性是有序的吗,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下

前言

最近有人问我,JavaScript对象属性是否一定是无序的、不可预测的?

早期接触过JavaScript的开发者可能会回答,​​Object.keys()​​或​​for...in​​会返回一个不可预知的对象属性顺序。

但现在的情况仍然是这样吗?

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

从ECMAScript 2020开始,​​Object.key​​​、​​for...in​​​、​​Object.getOwnPropertyNames​​​和​​Reflect.ownKeys​​都遵循同一个规范顺序。它们是:

自己的属性是数组的索引,按数字索引升序排列

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​​ 中。

自身的 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可以保证这一点。

到此这篇关于Javascript中的对象属性是有序的吗的文章就介绍到这了,更多相关Javascript对象属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于JavaScript短信验证码如何实现

    基于JavaScript短信验证码如何实现

    我们在使用移动、电信等运营商网上营业厅的时候,为确保业务的完整和正确性,经常会需要用到短信的验证码。最近因为某省业务需要,也做了个类似的功能
    2016-01-01
  • 一文详解JS与TS的主要区别

    一文详解JS与TS的主要区别

    TypeScript(简称 TS)和JavaScript(简称 JS)都是用于编写Web应用程序的语言,下面这篇文章主要给大家介绍了关于JS与TS的主要区别,需要的朋友可以参考下
    2024-03-03
  • 谈谈我对JavaScript DOM事件的理解

    谈谈我对JavaScript DOM事件的理解

    DOM与事件是JavaScript最核心的组成部分之一,他们赋予了页面无限的想象空间,你根本无法离开他们,否则js将寸步难行。本文给大家分享我对javascript dom事件的了解,对javascript dom事件相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • js实现简单的计算器功能

    js实现简单的计算器功能

    本文主要分享了js实现简单的计算器功能的示例代码。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-01-01
  • 效果直逼flash的Div+Css+Js菜单

    效果直逼flash的Div+Css+Js菜单

    效果直逼flash的Div+Css+Js菜单...
    2007-05-05
  • JavaScript 转义字符JSON parse错误研究

    JavaScript 转义字符JSON parse错误研究

    这篇文章主要为大家介绍了JavaScript 转义字符JSON parse错误研究,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • js数字计算 误差问题的快速解决方法

    js数字计算 误差问题的快速解决方法

    下面小编就为大家带来一篇js数字计算 误差问题的快速解决方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-02-02
  • 微信小程序npm引入vant-weapp的踩坑记录

    微信小程序npm引入vant-weapp的踩坑记录

    这篇文章主要给大家介绍了关于微信小程序npm引入vant-weapp的踩坑记录,文中通过示例代码介绍的非常详细,对大家学习或者使用微信小程序具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-08-08
  • js实现根据文件url批量压缩下载成zip包

    js实现根据文件url批量压缩下载成zip包

    本文主要介绍了js实现根据文件url批量压缩下载成zip包,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-02-02
  • JavaScript操作CSS的高级用法分享

    JavaScript操作CSS的高级用法分享

    Web开发中,JavaScript与CSS的结合用于增强网页的交互性和用户体验,本文将探索几种高级方法来使用JavaScript操作CSS,并分别通过代码示例进行讲解,希望对大家有所帮助
    2023-12-12

最新评论