我有一本格式为的字典

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
}

当前回答

试试这个:

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"}

其他回答

你可以这样做:

dictionary = {'ab': {object}, 'cd':{object}, 'ef':{object}}
var keys = Object.keys(dictionary);

for(var i = 0; i < keys.length;i++){
   //keys[i] for key
   //dictionary[keys[i]] for the value
}

欢迎来到2020 *流口水在ES6*

这里有一些相当老的答案——利用解构的优势。在我看来,这无疑是迭代对象最好的(非常可读的)方法。

const myObject = { 尼克:“笼子”, 菲尔:“墨”, }; Object.entries(myObject).forEach(([k,v]) => { console.log("The key: ", k) console.log("The value: ", v) })

编辑:

正如Lazerbeak所提到的,map允许您循环一个对象并使用键和值来创建数组。

const myObject = { 尼克:“笼子”, 菲尔:“墨”, }; const myArray = Object.entries(myObject)。Map (([k, v]) => { 键'${k}'的值为'${v}'; }); console.log (myArray);

编辑2:

要解释代码行中发生了什么:

Object.entries(myObject).forEach(([k,v]) => {}

object .entries()将对象转换为数组的数组:

[["nick", "cage"], ["phil", "murray"]]

然后我们在外层数组上使用forEach:

1st loop: ["nick", "cage"]
2nd loop: ["phil", "murray"]

然后我们用([k,v])“解构”值(我们知道它将始终是一个数组),因此k成为第一个名字,v成为最后一个名字。

试试这个:

var value;
for (var key in dictionary) {
    value = dictionary[key];
    // your code here...
}

您可以使用下面的脚本。

var obj={1:"a",2:"b",c:"3"};
for (var x=Object.keys(obj),i=0;i<x.length,key=x[i],value=obj[key];i++){
    console.log(key,value);
}

输出 1 2 b c 3

Object.entries()方法已经在ES2017中被指定(并且在所有现代浏览器中都被支持):

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…我们可以循环遍历这样创建的数组的项。 因为我们保证这样迭代的每个数组项本身都是一个有两个条目的数组,所以我们可以使用解构直接将变量key和value赋值给它的第一项和第二项。