我有一个格式为
字典。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
}
我有一个格式为
字典。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
}
在 ECMAScript 2017 中,只需调用 Object.entries(yourObj)
即可迭代对象。在 ECMAScript 2015 中,可以使用 Map
来实现。而在 ECMAScript 5 中,则无法实现。
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);
}
a 1
b 2
c 3
在ECMAScript 2015中,没有Object.entries
,但你可以使用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"]
或者使用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);
}
[ '0', 'foo' ]
[ 1, 'bar' ]
[ {}, 'baz' ]
for (const [key, value] of myMap.entries()) {
console.log(key, value);
}
0 foo
1 bar
{} baz
不可以使用对象实现。
你需要使用 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]);
}
}
注意:上面的 if
条件只有在你想迭代那些属于字典
对象自己的属性时才是必要的。因为 for...in
会遍历所有继承的可枚举属性。
或者
Object.keys(dictionary).forEach(function(key) {
console.log(key, dictionary[key]);
});
Object.keys(dictionary).forEach(function(key) {…
这段代码,它非常易读且兼容。 - ctrl-alt-delorObject.entries(object).forEach(([key, val]) => {...});
- Krimson试一下这个:
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"}
欢迎来到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)
})
编辑:
正如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);
编辑 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
变成了姓氏。
forEach
替换为map
,则可以聚合值。 map
然后将返回该值的列表,因此可能以其他方式简化代码。 - Lazerbeak12345Object.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 ... of
,我们可以循环遍历所创建数组中的条目。
由于我们保证每个被迭代的数组项本身都是一个含两个元素的数组,我们可以使用解构赋值直接将变量key
和value
分别赋值给其第一和第二项。
试一试:
var value;
for (var key in dictionary) {
value = dictionary[key];
// your code here...
}
你可以像这样做:
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
}
Object.entries(event).forEach(k => {
console.log("properties ... ", k[0], k[1]); });
请查看文档:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/entries
涉及IT技术相关内容,请您自行了解。${key} ${value}
);
}); - Hani_.forEach({ 'a': 1, 'b': 2 }, function(n, key) {
console.log(n, key);
});
作为对已接受答案的改进,为了减少嵌套,你可以这样做,前提是键没有被继承:
for (var key in dictionary) {
if (!dictionary.hasOwnProperty(key)) {
continue;
}
console.log(key, dictionary[key]);
}
Edit: info about Object.hasOwnProperty
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 a
2 b
c 3
for (let [key, value] of Object.entries(obj))
需要使用Babel。 (说明:这是一段JavaScript代码,使用了ES6中的解构赋值和Object.entries()方法。Babel是一个用于将新版本的JavaScript代码转换成旧版本兼容代码的工具。) - elclanrs