JS解惑之Object中的key是有序的么


Posted in Javascript onMay 06, 2019

当我们使用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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
两个select之间option的互相添加操作(jquery实现)
Nov 12 Javascript
JQuery从头学起第二讲
Jul 04 Javascript
js保存当前路径(cookies记录)
Dec 14 Javascript
能说明你的Javascript技术很烂的五个原因分析
Oct 28 Javascript
JQuery显示隐藏页面元素的方法总结
Apr 16 Javascript
jQuery插件boxScroll实现图片轮播特效
Jul 14 Javascript
JavaScript知识点总结(五)之Javascript中两个等于号(==)和三个等于号(===)的区别
May 31 Javascript
深究AngularJS中$sce的使用
Jun 12 Javascript
深入浅出es6模板字符串
Aug 26 Javascript
jQuery实现新闻播报滚动及淡入淡出效果示例
Mar 23 jQuery
jQuery的ztree仿windows文件新建和拖拽功能的实现代码
Dec 05 jQuery
JavaScript常见事件处理程序实例总结
Jan 05 Javascript
微信小程序和百度的语音识别接口详解
May 06 #Javascript
微信小程序生成海报分享朋友圈的实现方法
May 06 #Javascript
vue项目打包后上传至GitHub并实现github-pages的预览
May 06 #Javascript
Vue实现购物车的全选、单选、显示商品价格代码实例
May 06 #Javascript
JavaScript中关于base64的一些事
May 06 #Javascript
JavaScript中工厂函数与构造函数示例详解
May 06 #Javascript
微信小程序登录数据解密及状态维持实例详解
May 06 #Javascript
You might like
基于文本的访客签到簿
2006/10/09 PHP
PHP中获取时间的下一周下个月的方法
2014/03/18 PHP
PHP addcslashes()函数讲解
2019/02/03 PHP
利用JQuery动画制作滑动菜单项效果实现步骤及代码
2013/02/07 Javascript
JS前端框架关于重构的失败经验分享
2013/03/17 Javascript
判断输入是否为空,获得输入类型的JS代码
2013/10/30 Javascript
js中回调函数的学习笔记
2014/07/31 Javascript
jquery实现无限分级横向导航菜单的方法
2015/03/12 Javascript
WEB前端开发都应知道的jquery小技巧及jquery三个简写
2015/11/15 Javascript
jQuery前端开发35个小技巧
2016/05/24 Javascript
Javascript实现跑马灯效果的简单实例
2016/05/31 Javascript
jQuery animate easing使用方法图文详解
2016/06/17 Javascript
js智能获取浏览器版本UA信息的方法
2016/08/08 Javascript
AngularJs  E2E Testing 详解
2016/09/02 Javascript
javascript代码调试之console.log 用法图文详解
2016/09/30 Javascript
ReactJs快速入门教程(精华版)
2016/11/28 Javascript
html5+canvas实现支持触屏的签名插件教程
2017/05/08 Javascript
Vue组件模板形式实现对象数组数据循环为树形结构(实例代码)
2017/07/31 Javascript
Vue keep-alive实践总结(推荐)
2017/08/31 Javascript
vue添加class样式实例讲解
2019/02/12 Javascript
JavaScript数组及常见操作方法小结
2019/11/13 Javascript
解决echarts echarts数据动态更新和dataZoom被重置问题
2020/07/20 Javascript
[02:19]2018年度DOTA2最佳核心位选手-完美盛典
2018/12/17 DOTA
在ironpython中利用装饰器执行SQL操作的例子
2015/05/02 Python
举例讲解Python中的身份运算符的使用方法
2015/10/13 Python
python中matplotlib的颜色及线条控制的示例
2018/03/16 Python
Python系统监控模块psutil功能与经典用法分析
2018/05/24 Python
Python 实现数据结构中的的栈队列
2019/05/16 Python
python已协程方式处理任务实现过程
2019/12/27 Python
Python图像处理库PIL的ImageGrab模块介绍详解
2020/02/26 Python
Python实现一个优先级队列的方法
2020/07/31 Python
香港现代设计家具品牌:Ziinlife Furniture
2018/11/13 全球购物
static全局变量与普通的全局变量有什么区别
2014/05/27 面试题
搞笑创意广告语
2014/03/17 职场文书
节约用水演讲稿
2014/05/21 职场文书
机票销售员态度不好检讨书
2014/09/27 职场文书