如何在javascript中迭代(键、值)?

2024-04-25 09:06:04 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一本字典的格式是

dictionary = {0: {object}, 1:{object}, 2:{object}}

我怎么能做些类似于

for((key,value) in dictionary){
  //Do stuff where key would be 0 and value would be the object
}

Tags: andthekeyinfordictionary字典object
3条回答

试试这个:

dict = {0:{1:'a'}, 1:{2:'b'}, 2:{3:'c'}}
for (var key in dict){
  console.log( key, dict[key] );
}

0 Object { 1="a"}
1 Object { 2="b"}
2 Object { 3="c"}

在ES2017中指定了Object.entries()方法(并且是supported in all modern browsers):

for (const [ key, value ] of Object.entries(dictionary)) {
    // do something with `key` and `value`
}

说明:

  • Object.entries()接受类似于{ a: 1, b: 2, c: 3 }的对象,并将其转换为一个键值对数组:[ [ 'a', 1 ], [ 'b', 2 ], [ 'c', 3 ] ]

  • 使用for ... of我们可以循环访问这样创建的数组的条目。

  • 由于保证每个迭代数组项本身都是一个双项数组,因此我们可以使用destructuring直接将变量keyvalue赋给它的第一个和第二个项。

tl;博士

  1. 在ECMAScript 5中,这是不可能的。
  2. 在ECMAScript 2015中,可以使用Maps
  3. 在ECMAScript 2017中,它将很容易获得。

ECMAScript 5:

不,这是不可能的对象。

您应该使用^{}^{}进行迭代,如下所示

for (var key in dictionary) {
    // check if the property/key is defined in the object itself, not in parent
    if (dictionary.hasOwnProperty(key)) {           
        console.log(key, dictionary[key]);
    }
}

注意:上面的if条件是必要的,只要您想迭代对象本身的dictionary属性。因为for..in将遍历所有继承的可枚举属性。

或者

Object.keys(dictionary).forEach(function(key) {
    console.log(key, dictionary[key]);
});

ECMAScript 2015年

在ECMAScript 2015中,可以使用Map对象并用^{}迭代它们。引用那一页的例子

var myMap = new Map();
myMap.set("0", "foo");
myMap.set(1, "bar");
myMap.set({}, "baz");

var mapIter = myMap.entries();

console.log(mapIter.next().value); // ["0", "foo"]
console.log(mapIter.next().value); // [1, "bar"]
console.log(mapIter.next().value); // [Object, "baz"]

或者用^{}迭代,如下所示

'use strict';

var myMap = new Map();
myMap.set("0", "foo");
myMap.set(1, "bar");
myMap.set({}, "baz");

for (const entry of myMap.entries()) {
  console.log(entry);
}

输出

[ '0', 'foo' ]
[ 1, 'bar' ]
[ {}, 'baz' ]

或者

for (const [key, value] of myMap.entries()) {
  console.log(key, value);
}

输出

0 foo
1 bar
{} baz

ECMAScript 2017年

ECMAScript 2017将引入一个新函数^{}。你可以使用这个来迭代你想要的对象。

'use strict';

const object = {'a': 1, 'b': 2, 'c' : 3};
for (const [key, value] of Object.entries(object)) {
  console.log(key, value);
}

输出

a 1
b 2
c 3

相关问题 更多 >