您现在的位置是:亿华云 > IT科技类资讯
面试官:JavaScript对象属性是有序的吗?
亿华云2025-10-08 23:26:39【IT科技类资讯】6人已围观
简介最近有人问我,JavaScript对象属性是否一定是无序的、不可预测的?早期接触过JavaScript的开发者可能会回答,Object.keys()或for...in会返回一个不可预知的对象属性顺序。
最近有人问我,面试JavaScript对象属性是象属性有序否一定是无序的、不可预测的面试?
早期接触过JavaScript的开发者可能会回答,Object.keys()或for...in会返回一个不可预知的象属性有序对象属性顺序。
但现在的面试情况仍然是这样吗?
不是了,有些情况下是象属性有序有序的。
从ECMAScript 2020开始,面试Object.key、象属性有序for...in、面试Object.getOwnPropertyNames和Reflect.ownKeys都遵循同一个规范顺序。象属性有序它们是亿华云面试:
1. 自己的属性是数组的索引,按数字索引升序排列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 中。面试
2. 自身的 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可以保证这一点。
作者:islizeqiang
译者:小智
来源:medium
原文:https://medium.com/@
islizeqiang/are-javascript-object-properties-ordered-c30597754e5c很赞哦!(81925)
相关文章
- 域名资源有限,好域名更是有限,但机会随时都有,这取决于我们能否抓住机会。一般观点认为,国内域名注册太深,建议优先考虑外国注册人。外国注册人相对诚实,但价格差别很大,从几美元到几十美元不等。域名投资者应抓住机遇,尽早注册国外域名。
- 购买网站域名是好是坏怎么甄别?新手要怎么避开这些坑?
- 企业网站要怎么选合适域名?企业要如何做?
- 小白如果注册中文域名怎么做?有何具体步骤?
- 4、企业无形资产:通用网站已成为企业网络知识产权的重要组成部分,属于企业的无形资产,也有助于提升企业的品牌形象和技术领先形象。它是企业品牌资产不可或缺的一部分。
- 对企业注册域名流程有何看法?新手需要掌握哪几点?
- 新手在域名挑选时需要考量什么?如何做?
- 注册国外域名有什么不同方式?新手要注意哪几点?
- 第三,.cc域名域名也有很多优势资源域名,从整体注册基数也可以由此推断;
- 自己注册个人域名遇到难题怎么办?盘点个人域名注册问题