zoukankan      html  css  js  c++  java
  • for in 对象时,属性为非负整数的情况

    在我做一个需求的时候 for in 一个对象,对象的属性都是数字

    但是我想给这个对象加一个默认的属性跟值 

    原对象是{5446:"广州市"}。。。。。类似于下去

    然后我想给我页面展示出来的有一个默认的值 就是“选择城市”

    然后我在对象里面{"":"选择城市"}最前面加的

    但是现实并不像我想的那样 ,循环这个对象,选择城市在最上面,而是在最下面  但是我想不通啊  明明我的对象是{"":"选择城市",5446:"广州市".......}这样的

    为什么选择城市还在列表的最下面 然后我就去查资料了

    然后看到vue的官网说for in 是按照Object.keys来排序的

    Object.keys跟for ...in是一样的 (这句话不知道有没有问题)

    然后我就在控制台demo了一下

    var a={"":"123",name:"wenwen"}
    
    for(var i in a){console.log(i)}
    "" 
    name

    这是显示正常的

    然后但是奇怪的事情发生了,当属性是非负整数的时候

    会发生什么

    var a={"":"123",123:"这是一个数字123",12:"这是一个数字12"}
    
    
    for(var i in a){console.log(i)}
     12
     123
     ""

    发现问题了吗?事情并不像我想的那样 "" 123 12这样打印

    然后我就去查资料 发现了

    它们会先提取所有 key 的 parseFloat 值为非负整数的属性, 然后根据数字顺序对属性排序首先遍历出来,然后按照对象定义的顺序遍历余下的所有属性。其它浏览器则完全按照对象定义的顺序遍历属性。

    新版本中的属性遍历顺序说明与早期版本不同,这将导致遵循 ECMA-262 第三版规范内容实现的 JavaScript 解析引擎在处理 for-in 语句时,与遵循第五版规范实现的解析引擎,对属性的遍历顺序存在不一致的问题

    有什么想说的欢迎留言

  • 相关阅读:
    C++类构造函数初始化列表
    VC++检测硬件设备状态
    MFC中调用Windows API函数的方式
    DEBUG无法进入断点解决方法
    【转】c++数组初始化
    vc++实现控制USB设备启用与否
    3d图像坐标轴及css3属性的讲解
    Ajax的兼容及Ajax的缓存问题
    Ajax中最有名axios插件(只应用于Ajax)(post方法,官网写错了,应是字符串格式)
    文档碎片及xml讲解
  • 原文地址:https://www.cnblogs.com/lwwen/p/9303281.html
Copyright © 2011-2022 走看看