JS解惑之Object中的key是有序的么
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了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
回归到我最初遇到的问题,那就这么解决了
var obj = { '-1.': '全部', '0.' : '正常', '1.' : '失效' }; <select> <option v-for="(item, key) in obj" :value="~~key">{{item}}</option> </select>
参考
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:用Vue编写抽象组件的方法
下一篇:微信小程序和百度的语音识别接口详解
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程