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 相关文章推荐
提高代码性能技巧谈—以创建千行表格为例
Jul 01 Javascript
javascript和jquery修改a标签的href属性
Dec 16 Javascript
Base64(二进制)图片编码解析及在各种浏览器的兼容性处理
Feb 09 Javascript
Angularjs中使用指令绑定点击事件的方法
Mar 30 Javascript
JavaScript多线程运行库Nexus.js详解
Dec 22 Javascript
Vue.js@2.6.10更新内置错误处机制Fundebug同步支持相应错误监控
May 13 Javascript
javascript自定义日期比较函数用法示例
Jul 22 Javascript
python虚拟环境 virtualenv的简单使用
Jan 21 Javascript
详解React 条件渲染
Jul 08 Javascript
vue 解决uglifyjs-webpack-plugin打包出现报错的问题
Aug 04 Javascript
Vue通过provide inject实现组件通信
Sep 03 Javascript
vue 中使用print.js导出pdf操作
Nov 13 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 curl 并发最佳实践代码分享
2012/09/05 PHP
PHP array_multisort() 函数的深入解析
2013/06/20 PHP
PHP判断是否有Get参数的方法
2014/05/05 PHP
微信公众平台开发实现2048游戏的方法
2015/04/15 PHP
PHP hebrev()函数用法讲解
2019/02/21 PHP
js GridView 实现自动计算操作代码
2009/03/25 Javascript
纯JAVASCRIPT图表动画插件Highcharts Examples
2011/04/16 Javascript
js当一个变量为函数时 应该注意的一点细节小结
2011/12/29 Javascript
js Array对象的扩展函数代码
2013/04/24 Javascript
js获取事件源及触发该事件的对象
2013/10/24 Javascript
jQuery修改class属性和CSS样式整理
2015/01/30 Javascript
基于jQuery实现仿淘宝套餐选择插件
2015/03/04 Javascript
深入浅析jQuery对象$.html
2016/08/22 Javascript
微信小程序 引用其他js文件实现代码
2017/02/22 Javascript
JS简单实现滑动加载数据的方法示例
2017/10/18 Javascript
jQuery+Cookie实现切换皮肤功能【附源码下载】
2018/03/25 jQuery
JavaScript求一个数组中重复出现次数最多的元素及其下标位置示例
2018/07/23 Javascript
validform表单验证的实现方法
2019/03/08 Javascript
javascript移动端 电子书 翻页效果实现代码
2019/09/07 Javascript
JS在Array数组中按指定位置删除或添加元素对象方法示例
2019/11/19 Javascript
JavaScript arguments.callee作用及替换方案详解
2020/09/02 Javascript
在antd4.0中Form使用initialValue操作
2020/11/02 Javascript
python 合并文件的具体实例
2013/08/08 Python
pandas中read_csv、rolling、expanding用法详解
2020/04/21 Python
Pycharm安装并配置jupyter notebook的实现
2020/05/18 Python
柏林通行证:Berlin Pass
2018/04/11 全球购物
英国旅行箱包和行李箱购物网站:Travel Luggage & Cabin Bags
2019/08/26 全球购物
工程造价与财务管理专业应届生求职信
2013/10/06 职场文书
社区端午节活动方案
2014/01/28 职场文书
家长给小学生的评语
2014/01/30 职场文书
校园十大歌手策划书
2014/02/01 职场文书
某某店铺的开业庆典主持词范本
2019/11/25 职场文书
MySQL之高可用集群部署及故障切换实现
2021/04/22 MySQL
如何用JS实现简单的数据监听
2021/05/06 Javascript
QT与javascript交互数据的实现
2021/05/26 Javascript
python 判断字符串当中是否包含字符(str.contain)
2022/06/01 Python