JS解惑之Object中的key是有序的么
当我们使⽤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
最后
js的基本数据类型回归到我最初遇到的问题,那就这么解决了:
var obj = {
'-1.': '全部',
'0.' : '正常',
'1.' : '失效'
};
<select>
<option v-for="(item, key) in obj" :value="~~key">{{item}}</option>
</select>
参考
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论