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 相关文章推荐
小议javascript 设计模式 推荐
Oct 28 Javascript
锋利的jQuery 要点归纳(三) jQuery中的事件和动画(上:事件篇)
Mar 24 Javascript
jquery.tmpl JQuery模板插件
Oct 10 Javascript
Three.js源码阅读笔记(物体是如何组织的)
Dec 27 Javascript
jquery将一个表单序列化为一个对象的方法
Jan 03 Javascript
推荐10 款 SVG 动画的 JavaScript 库
Mar 24 Javascript
ECMAScript6块级作用域及新变量声明(let)
Jun 12 Javascript
以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题
Nov 13 Javascript
Javascript小技能总结(推荐)
Jun 02 Javascript
Vue.js实现按钮的动态绑定效果及实现代码
Aug 21 Javascript
解决vue2中使用axios http请求出现的问题
Mar 05 Javascript
Async/Await替代Promise的6个理由
Jun 15 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
探讨PHP函数ip2long转换IP时数值太大产生负数的解决方法
2013/06/06 PHP
php.ini 配置文件的深入解析
2013/06/17 PHP
PHP临时文件的安全性分析
2014/07/04 PHP
wordpress安装过程中遇到中文乱码的处理方法
2015/04/21 PHP
文件上传之SWFUpload插件(代码)
2015/07/30 PHP
JS获取父节点方法
2009/08/20 Javascript
基于jquery的超简单上下翻
2010/04/20 Javascript
解决遍历时Array.indexOf产生的性能问题
2012/07/03 Javascript
jquery获取radio值实例
2014/10/16 Javascript
js实现精美的图片跟随鼠标效果实例
2015/05/16 Javascript
jquery分页插件jquery.pagination.js使用方法解析
2016/04/01 Javascript
vue指令以及dom操作详解
2017/03/04 Javascript
JavaScript评论点赞功能的实现方法
2017/03/13 Javascript
jQuery Jsonp跨域模拟搜索引擎
2017/06/17 jQuery
Layui点击图片弹框预览的实现方法
2019/09/16 Javascript
JavaScript实现京东放大镜效果
2019/12/03 Javascript
在vue中使用axios实现post方式获取二进制流下载文件(实例代码)
2019/12/16 Javascript
element-ui树形控件后台返回的数据+生成组织树的工具类
2020/03/05 Javascript
只有 20 行的 JavaScript 模板引擎实例详解
2020/05/11 Javascript
Python处理JSON数据并生成条形图
2016/08/05 Python
python使用tensorflow深度学习识别验证码
2018/04/03 Python
致Python初学者 Anaconda入门使用指南完整版
2018/04/05 Python
Python使用re模块正则提取字符串中括号内的内容示例
2018/06/01 Python
对python的输出和输出格式详解
2018/12/08 Python
Python 可变类型和不可变类型及引用过程解析
2019/09/27 Python
Python下应用opencv 实现人脸检测功能
2019/10/24 Python
Python word文本自动化操作实现方法解析
2020/11/05 Python
法国包包和行李箱销售网站:Bagage24.fr
2020/03/24 全球购物
IBatis持久层技术
2016/07/18 面试题
公司开业庆典主持词
2014/03/21 职场文书
文艺晚会主持词
2014/03/24 职场文书
电子专业求职信
2014/06/19 职场文书
离婚协议书怎样才有法律效力
2014/10/10 职场文书
2014年个人总结范文
2015/03/09 职场文书
电影开国大典观后感
2015/06/04 职场文书
详解RedisTemplate下Redis分布式锁引发的系列问题
2021/04/27 Redis