tl;博士
- 在 ECMAScript 2017 中,只需调用 .
Object.entries(yourObj)
- 在 ECMAScript 2015 中,可以使用 s。
Map
- 在 ECMAScript 5 中,这是不可能的。
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);
}
输出
a 1
b 2
c 3
ECMAScript 2015
在 ECMAScript 2015 中没有,但您可以使用对象来代替,并使用 Map.prototype.entries
迭代它们。引用该页面中的示例,Object.entries
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"]
或者用 for.. 迭代。的
,像这样
'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 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]);
}
}
注意:仅当要循环访问对象自己的属性时,上述条件才是必需的。因为将循环访问所有继承的可枚举属性。if
dictionary
for..in
或
Object.keys(dictionary).forEach(function(key) {
console.log(key, dictionary[key]);
});