JS解惑之Object中的key是有序的么

时间:2021-05-26

当我们使用for/in遍历一个Object对象的时候,打印的结果是否按key的顺序打印出来呢?

答案是:不一定。

背景

最近在做一个项目的时候,遇到这样一个需求:

一个下拉列表中有3个固定选项,包括:-1:全部;0:正常;1:失效。

于是,我就定义了一个对象,然后循环这个对象,把结果放到 <option> 上面:

var obj = { '-1': '全部', '0' : '正常', '1' : '失效'};<!-- Vue代码片段 --><select> <option v-for="(item, key) in obj" :value="key">{{item}}</option></select><!-- 结果却是: --><!-- 0 正常 --><!-- 1 失效 --><!-- -1 全部 -->

于是就有了今天这篇文章,且看下文。

解惑

Object的key的排序规则到底是什么样子的呢?答案是:

如果key是整数(如:123)或者整数类型的字符串(如:“123”),那么会按照从小到大的排序。除此之外,其它数据类型,都安装对象key的实际创建顺序排序。

var obj = { '-1': '全部', '0' : '正常', '1' : '失效'};for (let key in obj) { console.log(key, obj[key]);};// result// 0 正常// 1 失效// -1 全部

另外,如果key中除了整数或者整数类型的字符串外,还含有其它数据类型,则整数放在最前面,比如:

var obj = { 'a': 111, '我' : 222, '1' : 333, '1.3': 444, '3': 555};for (let key in obj) { console.log(key, obj[key]);};// result// 1 333// 3 555// a 111// 我 222// 1.3 444

解决

那还是上面的问题,我如何让对象按key的顺序输出呢?答案是:

将key转换成非整数类型的字符串,使用的时候再还原。

如果全部是类整数的key,则可以这么做:

// 每个key后面加.转换成字符串var obj = { '-1.': '全部', '0.' : '正常', '1.' : '失效'};for (let key in obj) { // ~~ 表示转换成整数,这样上面的key又还原成了-1/0/1 console.log(~~key, obj[key]);};// result// -1 全部// 0 正常// 1 失效

但是,如果key是由各种数据类型混合的,那就不能转换成整数了,可以这么做:

// 每个key前面加.转换成字符串var obj = { '.a': 111, '.我' : 222, '.1' : 333, '.1.3': 444, '.3': 555};for (let key in obj) { // 从第1个字符取原始的key console.log(key.substring(1), obj[key]);};// result// a 111// 我 222// 1 333// 1.3 444// 3 555

最后

回归到我最初遇到的问题,那就这么解决了:

var obj = { '-1.': '全部', '0.' : '正常', '1.' : '失效'};<select> <option v-for="(item, key) in obj" :value="~~key">{{item}}</option></select>

参考

Objects#ordered-like-an-object

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章