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

nbr*_*ing 255 javascript iteration object

我有一个格式为的字典

dictionary = {0: {object}, 1:{object}, 2:{object}}
Run Code Online (Sandbox Code Playgroud)

我怎样才能通过做类似的事情来遍历这本词典

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

the*_*eye 375

TL;博士

  1. 在ECMAScript 5中,它是不可能的.
  2. 在ECMAScript 2015中,可以使用Maps.
  3. 在ECMAScript 2017中,它将随时可用.

ECMAScript 5:

不,它不可能与对象.

您应该使用for..in,或者Object.keys像这样迭代

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]);
    }
}
Run Code Online (Sandbox Code Playgroud)

注:if上面的条件是必要的,只有当你要重复它们的属性dictionary对象的自己.因为for..in将遍历所有继承的可枚举属性.

要么

Object.keys(dictionary).forEach(function(key) {
    console.log(key, dictionary[key]);
});
Run Code Online (Sandbox Code Playgroud)

ECMAScript 2015

在ECMAScript 2015中,您可以使用Map对象并使用它们进行迭代Map.prototype.entries.从该页面引用示例,

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"]
Run Code Online (Sandbox Code Playgroud)

for..of像这样迭代

'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);
}
Run Code Online (Sandbox Code Playgroud)

产量

[ '0', 'foo' ]
[ 1, 'bar' ]
[ {}, 'baz' ]
Run Code Online (Sandbox Code Playgroud)

要么

for (const [key, value] of myMap.entries()) {
  console.log(key, value);
}
Run Code Online (Sandbox Code Playgroud)

产量

0 foo
1 bar
{} baz
Run Code Online (Sandbox Code Playgroud)

ECMAScript 2017

ECMAScript 2017将引入一项新功能Object.entries.您可以使用它来根据需要迭代对象.

'use strict';

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

产量

a 1
b 2
c 3
Run Code Online (Sandbox Code Playgroud)

  • `Object.entries(object).forEach(([[key,val])=> {...});` (3认同)
  • 这里有一个基本的疑问。我来到这里寻找如何在 node.js 中执行此操作,它是服务器端的 javascript。我怎么知道哪个 ES 版本适用于我的情况。另外,对于普通的 javascript 用户,据我所知,ES 版本取决于客户端的浏览器,支持的正确方法是什么? (2认同)
  • @SandeepanNath您可以使用https://node.green/等网站来了解Node.js是否支持特定的ES功能.就浏览器而言,人们通常针对广泛支持的版本,在本例中为ES5.除此之外,转发器(如[Babel](https://babeljs.io/))有助于将ES2015 +代码转换为ES5. (2认同)
  • 我喜欢 `Object.keys(dictionary).forEach(function(key) {...` 非常可读且兼容。 (2认同)

Ste*_*eve 47

欢迎来到 2020 * ES6 中的 Drools*

这里有一些非常古老的答案 - 利用解构。在我看来,这无疑是迭代对象的最好(非常易读)的方式。

const myObject = {
    nick: 'cage',
    phil: 'murray',
};

Object.entries(myObject).forEach(([k,v]) => {
    console.log("The key: ", k)
    console.log("The value: ", v)
})
Run Code Online (Sandbox Code Playgroud)

编辑:

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

const myObject = {
    nick: 'cage',
    phil: 'murray',
};

const myArray = Object.entries(myObject).map(([k, v]) => {
    return `The key '${k}' has a value of '${v}'`;
});

console.log(myArray);
Run Code Online (Sandbox Code Playgroud)

编辑2:

解释代码行中发生的事情:

Object.entries(myObject).forEach(([k,v]) => {}
Run Code Online (Sandbox Code Playgroud)

Object.entries() 将我们的对象转换为数组数组:

[["nick", "cage"], ["phil", "murray"]]
Run Code Online (Sandbox Code Playgroud)

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

1st loop: ["nick", "cage"]
2nd loop: ["phil", "murray"]
Run Code Online (Sandbox Code Playgroud)

然后我们“解构”这个值(我们知道它总是一个数组),([k,v])sok成为名字并v成为姓氏。

  • 请注意:如果将上面的“forEach”替换为“map”,则可以聚合值。然后“map”将返回所述值的列表,从而可能以其他方式简化代码。 (2认同)

ale*_*x10 46

试试这个:

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"}
Run Code Online (Sandbox Code Playgroud)

  • 这应该是公认的答案。接受答案这么久了。 (2认同)

Loi*_*ilo 34

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

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

说明:

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

  • 随着for ... of我们可以通过这样制作的磁盘阵列的每个条目循环.

  • 由于我们保证,每个迭代如此数组项的是另一种双项数组,我们可以用解构直接分配变量key,并value在其第一和第二项.


AMA*_*ACB 12

试试这个:

var value;
for (var key in dictionary) {
    value = dictionary[key];
    // your code here...
}
Run Code Online (Sandbox Code Playgroud)


Dha*_*ary 10

您可以执行以下操作:

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
}
Run Code Online (Sandbox Code Playgroud)

  • 美丽的!我喜欢你的答案在 ECMAscript 5 中的工作方式,尽管接受和投票最多的答案说这是不可能的。你应该得到更多的赞成票。 (3认同)

小智 5

我认为快速简便的方法是

Object.entries(event).forEach(k => {
    console.log("properties ... ", k[0], k[1]); });
Run Code Online (Sandbox Code Playgroud)

只需查看文档 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries

  • 甚至更好: Object.entries(obj).forEach(([key, value]) =&gt; { console.log(`${key} ${value}`); }); (2认同)