javascript对象属性/数组操作

时间:2011-12-30 03:33:18

标签: javascript arrays object

一些对象属性/数组操作。是否有更好的语法来完成第2部分和第3部分?

// 1. create object and add element/arrays
var myObject = {};
myObject["123"] = { "A": 123, "B": 456 };  // add 
myObject["123"] = { "C": 123, "D": 456 };  // add more elements to array in element!
myObject["124"] = { "A": 123, "B": 456 };
myObject["125"] = { "A": 123, "B": 456 };
console.log(myObject);

// 2. delete first property in array
for (property in myObject){
        delete myObject[property];
        break;
    }

// 3. show first remaining property
for (property in myObject){
        x = property;
        console.log("first remaining property is " + x );
        break;
    }

3 个答案:

答案 0 :(得分:2)

我不确定为什么你只使用对象文字语法(JSON模仿对象文字声明),但它也为你创建了一个bug。你在第二次任务中覆盖了myObject [“123”]。

您可以更简单地将整个第1部分写为:

var myObject = {
    "123": {
        "A": 123,
        "B": 456,
        "C": 123,
        "D": 456
    },
    "124": {
        "A": 123,
        "B": 456
    },
    "125": {
        "A": 123,
        "B": 456
    }
}

第二和第三,没有“数组中的第一个属性”这样的东西。对于编写javascript的人来说,这是一个非常常见的错误(不仅仅是新人,而是多年来一直在写这篇文章的人)。

在任何情况下对象的任何部分永远“第一”或“第二”或在对象中有任何顺序。 ECMA-262规范中清楚地概述了这一点。浏览器供应商有时会适应这种行为,这就是为什么“它有效”的原因。

这是因为对象不是数组,也不是数组。如果您希望事物按数组的顺序排列,则需要使用数组。让我问你,文档对象中的“第一个”元素是什么?显然这是一个愚蠢的问题,但它证明了这一点。对象不维护顺序,这就是数组的作用。

所以使用一个数组。方括号表示一个数组,它不会将字符串作为键(这是对象所做的事情)。为了使事情更加混乱,数组是对象,因此它们可以像对象一样 - 不要混淆它,并认为对象是数组。

答案 1 :(得分:1)

myObject["123"] = { "C": 123, "D": 456 }; 

对象(关联数组)添加更多元素,它会替换它们;添加你必须写的元素:

myObject["123"].C =123;
myObject["123"].D = 456;

对于#2和#3,Javascript对象不保证按照添加顺序返回属性;为此你必须求助于一个数组,然后在将数据调整到不同数据结构的限制之后,你可以得到第一个元素:

myArray.shift()

答案 2 :(得分:0)

您可以在支持它的浏览器中使用Object.keys()

console.log("first remaining property is " + Object.keys(myObject)[0] );

虽然我不确定这两种方法都能保证订单。