您现在的位置是:网站首页> 编程资料编程资料
Javascript中的对象属性是有序的吗_javascript技巧_
2023-05-24
418人已围观
简介 Javascript中的对象属性是有序的吗_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对象属性内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- 使用Express+Node.js对mysql进行增改查操作 _node.js_
- vue中设置滚动条方式_vue.js_
- Windows下安装NodeJS的详细步骤_node.js_
- 8个鲜为人知但很实用的Web API用法总结_javascript技巧_
- vue使用axios导出后台返回的文件流为excel表格详解_vue.js_
- 浅析一下Vue3的响应式原理_vue.js_
- React中父组件如何获取子组件的值或方法_React_
- Vue中实现过渡动画效果示例代码_vue.js_
- vue进入页面加载数据缓慢实现loading提示过程_vue.js_
- Vue实现让页面加载时请求后台接口数据_vue.js_
