我有一本格式为的字典
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
}
当前回答
您可以使用下面的脚本。
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
其他回答
作为对接受答案的改进,为了减少嵌套,你可以这样做,只要键不是继承的:
for (var key in dictionary) {
if (!dictionary.hasOwnProperty(key)) {
continue;
}
console.log(key, dictionary[key]);
}
编辑:关于对象的信息。hasOwnProperty这里
试试这个:
var value;
for (var key in dictionary) {
value = dictionary[key];
// your code here...
}
我认为最快最简单的方法是
Object.entries(event).forEach(k => {
console.log("properties ... ", k[0], k[1]); });
看看文档就知道了 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/entries
你可以使用JavaScript forEach循环:
myMap.forEach((value, key) => {
console.log('value: ', value);
console.log('key: ', key);
});
欢迎来到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成为最后一个名字。