本篇文章介绍JS解惑之Object中的key是有序的么。 当我们使用for/in遍历一个Object对象的时候,打印的结果是否按key的顺序打印出来呢? 答案是:不一定。 背景 最近在做一个项目的时候,遇到这样一个需求: 一个下拉列表中有3个固定选项,包括:-1:全部;0:
本篇文章介绍JS解惑之Object中的key是有序的么。 当我们使用for/in遍历一个Object对象的时候,打印的结果是否按key的顺序打印出来呢? 答案是:不一定。 背景 最近在做一个项目的时候,遇到这样一个需求: 一个下拉列表中有3个固定选项,包括:-1:全部;0:正常;1:失效。 于是,我就定义了一个对象,然后循环这个对象,把结果放到 <option> 上面:
于是就有了今天这篇文章,且看下文。 解惑 Object的key的排序规则到底是什么样子的呢?答案是: 如果key是整数(如:123)或者整数类型的字符串(如:“123”),那么会按照从小到大的排序。除此之外,其它数据类型,都安装对象key的实际创建顺序排序。
另外,如果key中除了整数或者整数类型的字符串外,还含有其它数据类型,则整数放在最前面,比如:
解决 那还是上面的问题,我如何让对象按key的顺序输出呢?答案是: 将key转换成非整数类型的字符串,使用的时候再还原。 如果全部是类整数的key,则可以这么做:
但是,如果key是由各种数据类型混合的,那就不能转换成整数了,可以这么做:
最后 回归到我最初遇到的问题,那就这么解决了:
|
2021-06-04
2019-01-10
2019-02-17
2021-09-12
2021-09-30