当我们使用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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 黑鸭子2008-今生最爱[首版][WAV+CUE]
- 彭海桐.2000-好好想想你【SONY】【WAV+CUE】
- 群星.1995-亚洲电视剧集主题曲大全·乐作剧2CD【滚石】【WAV+CUE】
- 林强.1992-春风少年兄【魔岩】【WAV+CUE】
- 世界顶级汽车音响试音王《金色的草原》24K金碟[低速原抓WAV+CUE][1G]
- 周深 /Faouzia《解密 电影原声带》[320K/MP3][39.32MB]
- 周深 /Faouzia《解密 电影原声带》[FLAC/分轨][199.46MB]
- 英雄联盟s14亚军队伍是哪支 英雄联盟s14亚军队伍介绍
- 英雄联盟s14夺冠队伍是哪支 英雄联盟s14夺冠队SKT T1队伍介绍
- faker三冠王是哪几个赛季 faker三冠王赛季介绍
- 岩贵-音乐磁场(AI调音)2CD[WAV]
- 童丽《千愁记旧情》HQII头版限量编号2024[低速原抓WAV+CUE]
- 瑞鸣十五周年纪念3[HQCD限量编号头版][低速原抓WAV+CUE]
- 任天堂专利展示新VR外设:或会随同NS继任机型推出
- 博主制作“Switch 2”模型 与现有掌机对比