JS解惑之Object中的key是有序的么
当我们使用for/in遍历一个Object对象的时候,打印的结果是否按key的顺序打印出来呢?
答案是:不一定。
背景
最近在做一个项目的时候,遇到这样一个需求:
一个下拉列表中有3个固定选项,包括:-1:全部;0:正常;1:失效。
于是,我就定义了一个对象,然后循环这个对象,把结果放到
varobj={
'-1':'全部',
'0':'正常',
'1':'失效'
};
于是就有了今天这篇文章,且看下文。
解惑
Object的key的排序规则到底是什么样子的呢?答案是:
如果key是整数(如:123)或者整数类型的字符串(如:“123”),那么会按照从小到大的排序。除此之外,其它数据类型,都安装对象key的实际创建顺序排序。
varobj={
'-1':'全部',
'0':'正常',
'1':'失效'
};
for(letkeyinobj){
console.log(key,obj[key]);
};
//result
//0正常
//1失效
//-1全部
另外,如果key中除了整数或者整数类型的字符串外,还含有其它数据类型,则整数放在最前面,比如:
varobj={
'a':111,
'我':222,
'1':333,
'1.3':444,
'3':555
};
for(letkeyinobj){
console.log(key,obj[key]);
};
//result
//1333
//3555
//a111
//我222
//1.3444
解决
那还是上面的问题,我如何让对象按key的顺序输出呢?答案是:
将key转换成非整数类型的字符串,使用的时候再还原。
如果全部是类整数的key,则可以这么做:
//每个key后面加.转换成字符串
varobj={
'-1.':'全部',
'0.':'正常',
'1.':'失效'
};
for(letkeyinobj){
//~~表示转换成整数,这样上面的key又还原成了-1/0/1
console.log(~~key,obj[key]);
};
//result
//-1全部
//0正常
//1失效
但是,如果key是由各种数据类型混合的,那就不能转换成整数了,可以这么做:
//每个key前面加.转换成字符串
varobj={
'.a':111,
'.我':222,
'.1':333,
'.1.3':444,
'.3':555
};
for(letkeyinobj){
//从第1个字符取原始的key
console.log(key.substring(1),obj[key]);
};
//result
//a111
//我222
//1333
//1.3444
//3555
最后
回归到我最初遇到的问题,那就这么解决了:
varobj={
'-1.':'全部',
'0.':'正常',
'1.':'失效'
};
参考
Objects#ordered-like-an-object
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。