博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JS解惑-Object中的key是有序的么?
阅读量:6827 次
发布时间:2019-06-26

本文共 1468 字,大约阅读时间需要 4 分钟。

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

答案是:不一定

背景

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

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

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

var obj = {    '-1': '全部',    '0' : '正常',    '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.' : '失效'};复制代码
复制代码

参考

转载地址:http://ivfkl.baihongyu.com/

你可能感兴趣的文章
波士顿房价处理
查看>>
bootstrap-table设置某列序号自增
查看>>
让IIS8支持WCF的最简单方法
查看>>
多一个“点”给IIS与ASP.NET带来的问题
查看>>
XHTML学习资料(五)—— 表单
查看>>
练习题解答(一)
查看>>
RabbitMQ 应用二
查看>>
zabbix监控tomcat与安全规范
查看>>
Ubuntu-10.10如何给用户添加sudo权限
查看>>
记录系统日志方法
查看>>
摘自当当网的36类商品分类菜单
查看>>
js判断客户端是pc还是手机
查看>>
cast——java类型转换
查看>>
linux 切换c++版本
查看>>
静态方法和实例方法联系与区别
查看>>
java 正则获取html的值
查看>>
NOI2015
查看>>
Eclipse导入别人项目爆红叉
查看>>
JVM(四、尝试编写类加载器)
查看>>
Extjs 4.2使用心得 --- store和reader使用技巧
查看>>