最近有人问我,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 中。
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
本文名称:面试官:JavaScript对象属性是有序的吗?
文章URL:http://www.csdahua.cn/qtweb/news16/155766.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网