一些对象属性/数组操作。是否有更好的语法来完成第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;
}
答案 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] );
虽然我不确定这两种方法都能保证订单。