热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Object.keys()是按什么递次返回值的?

碰到了一个很有意义的题目,js中对象属性的输出是有序的吗?假如有的话,那又遵照如何的划定规矩呢?这里我们来做一个简朴的讨论,事情之余来一点趣味性的题目。虽不能醍醐灌顶,但能够稳固所

碰到了一个很有意义的题目,js中对象属性的输出是有序的吗?假如有的话,那又遵照如何的划定规矩呢?

这里我们来做一个简朴的讨论,事情之余来一点趣味性的题目。虽不能醍醐灌顶,但能够稳固所学学问,也是极好的~🙈

一、新鲜征象

我们来看如许一个对象,来输出他的属性称号,也就是key值:

var data = {'1':'#','2':'bbb','3':'ccc','测试':'000'};
Object.keys(data) ;
["1", "2", "3", "测试"]

嗯,没啥题目。那调解一下末了一项的位置,再来尝尝:

var data = {'测试':'000','1':'#','2':'bbb','3':'ccc'};
Object.keys(data);
["1", "2", "3", "测试"]

新鲜,输出的递次被调解了,这是为何呢?我们继承,换一下属性称号,再试一次:

var data = {'a':'000','1':'#','2':'bbb','3':'ccc'};
Object.keys(data);
["1", "2", "3", "a"]

依效果来看,貌似有点小规律,我们无妨猜一下。

二、斗胆勇敢猜想

我们来看效果:

["1", "2", "3", "测试"]
["1", "2", "3", "a"]

会不会是依据ASC码的大小递次来输出的呢?

'1'<'2'<'3'<'测试'
'1'<'2'<'3'<'a'

彷佛漏掉了一种状况(字母和汉字的属性称号同时存在),我们试一下:

var data = {'a':'000','3':'ccc','1':'#','测试':'bbb',};
Object.keys(data);
["1", "3", "a", "测试"]

调解属性’a’和’测试’的递次呢?

var data = {'测试':'bbb','3':'ccc','a':'000','1':'#'};
Object.keys(data);
["1", "3", "测试", "a"]

好了,到此为止,我们能够得出结论了。

结论:对象的遍历输出并不是依据属性的ASC码升序排序的。

三、初见端倪

查阅了一些文档后,得出了以下有用结论:

1.An object is a member of the type Object. It is an unordered collection of properties each of which contains a primitive value,

object, or function. A function stored in a property of an object is

called a method.

2.Chrome Opera 的 Javascript 剖析引擎遵照的是新版 ECMA-262 第五版范例。因而,运用 for-in 语句遍历对象属性时遍历书序并不是属性构建递次。而 IE6 IE7 IE8 Firefox Safari 的 Javascript
剖析引擎遵照的是较老的 ECMA-262 第三版范例,属性遍历递次由属性构建的递次决议。

四、水落石出

Chrome Opera 中运用 for-in 语句遍历对象属性时会遵照一个规律:

它们会先提取一切 key 的 parseFloat 值为非负整数的属性,然后依据数字递次对属性排序起首遍历出来,然后依据对象定义的递次遍历余下的一切属性。

别的浏览器则完整依据对象定义的递次遍历属性。
这和我们上面例子中的数据效果是符合的,嗯,这就是我想要的效果!

五、了案总结

假如想递次遍历一组数据,请运用数组并运用 for 语句遍历。

for-in语句没法保证遍历递次,应只管防止编写依靠对象属性递次的代码。假如想依据定义的序次遍历对象属性,请参考这里针对各浏览器编写特别代码。

因为对象的输出是无序的,然则数组倒是有序的,所以为了保证递次,搞成数组再输出。嗯,就是如许!

六、参考文档
1.ASCII参照表
http://baike.baidu.com/link?u&#8230;
2.js对象输出递次
http://stackoverflow.com/ques&#8230;
3.遍历出的属性递次与对象定义时差别
http://w3help.org/zh-cn/cause&#8230;
4.掌握js中的对象递次输出
https://segmentfault.com/q/10&#8230;


推荐阅读
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 如何使用Java获取服务器硬件信息和磁盘负载率
    本文介绍了使用Java编程语言获取服务器硬件信息和磁盘负载率的方法。首先在远程服务器上搭建一个支持服务端语言的HTTP服务,并获取服务器的磁盘信息,并将结果输出。然后在本地使用JS编写一个AJAX脚本,远程请求服务端的程序,得到结果并展示给用户。其中还介绍了如何提取硬盘序列号的方法。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • 本文整理了常用的CSS属性及用法,包括背景属性、边框属性、尺寸属性、可伸缩框属性、字体属性和文本属性等,方便开发者查阅和使用。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • http:my.oschina.netleejun2005blog136820刚看到群里又有同学在说HTTP协议下的Get请求参数长度是有大小限制的,最大不能超过XX ... [详细]
  • JavaScript简介及语言特点
    本文介绍了JavaScript的起源和发展历程,以及其在前端验证和服务器端开发中的应用。同时,还介绍了ECMAScript标准、DOM对象和BOM对象的作用及特点。最后,对JavaScript作为解释型语言和编译型语言的区别进行了说明。 ... [详细]
  • ECMA262规定typeof操作符的返回值和instanceof的使用方法
    本文介绍了ECMA262规定的typeof操作符对不同类型的变量的返回值,以及instanceof操作符的使用方法。同时还提到了在不同浏览器中对正则表达式应用typeof操作符的返回值的差异。 ... [详细]
  • 本文介绍了网页播放视频的三种实现方式,分别是使用html5的video标签、使用flash来播放以及使用object标签。其中,推荐使用html5的video标签来简单播放视频,但有些老的浏览器不支持html5。另外,还可以使用flash来播放视频,需要使用object标签。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • css,背景,位置,y,background, ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 成功安装Sabayon Linux在thinkpad X60上的经验分享
    本文分享了作者在国庆期间在thinkpad X60上成功安装Sabayon Linux的经验。通过修改CHOST和执行emerge命令,作者顺利完成了安装过程。Sabayon Linux是一个基于Gentoo Linux的发行版,可以将电脑快速转变为一个功能强大的系统。除了作为一个live DVD使用外,Sabayon Linux还可以被安装在硬盘上,方便用户使用。 ... [详细]
  • python+selenium十:基于原生selenium的二次封装fromseleniumimportwebdriverfromselenium.webdriv ... [详细]
author-avatar
手机用户2502887521
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有