我在JavaScript中有一个对象:
{
abc: '...',
bca: '...',
zzz: '...',
xxx: '...',
ccc: '...',
// ...
}
我想用一个for循环来获取它的属性。我想要迭代它的部分(不是所有的对象属性一次)。
对于一个简单的数组,我可以用一个标准的for循环来做:
for (i = 0; i < 100; i++) { ... } // first part
for (i = 100; i < 300; i++) { ... } // second
for (i = 300; i < arr.length; i++) { ... } // last
但是如何对对象进行处理呢?
使用对象。你这样做。
// array like object with random key ordering
const anObj = { 100: 'a', 2: 'b', 7: 'c' };
console.log(Object.entries(anObj)); // [ ['2', 'b'],['7', 'c'],['100', 'a'] ]
object .entries()方法返回给定对象自身可枚举属性[key, value]的数组。
你可以遍历对象每个对象都有键和值,得到这样的东西。
const anObj = { 100: 'a', 2: 'b', 7: 'c' };
Object.entries(anObj).map(obj => {
const key = obj[0];
const value = obj[1];
// do whatever you want with those values.
});
或者像这样
// Or, using array extras
Object.entries(obj).forEach(([key, value]) => {
console.log(`${key} ${value}`); // "a 5", "b 7", "c 9"
});
参考MDN文档中的对象条目
如果你有一个简单的对象,你可以使用下面的代码迭代它:
let myObj = {
美国广播公司(abc):“…”
bca:“……”
鼾声大作:“……”
xxx:“……”
ccc:“……”
/ /……
};
let objKeys = Object.keys(myObj);
//现在我们可以使用objKeys遍历myObj
for (item of objKeys) {
//这将打印密钥
console.log(关键:,项);
//这将打印出值
console.log(价值:,myObj[项目]);
}
如果你有一个嵌套对象,你可以使用下面的代码遍历它:
设b = {
一:{
答:1,
b: 2
c: 3
},
二:{
4,
b: 5
c: 6
},
三:{
7,
b: 8
c: 9
}
};
let myKeys = Object.keys(b);
for (item of myKeys) {
//打印密钥
console.log(“关键”,项目)
//打印值(这将是另一个对象)
console.log(“价值”,b[项目])
//打印嵌套值
console.log('嵌套值',b[item]['a'])
}
如果你有一个对象数组,你可以使用下面的代码遍历它:
令c = [
{
答:1,
b: 2
},
{
答:3,
b: 4
}
];
对于(c项){
//单独打印整个对象
console.log(“对象”,项目);
//打印对象内部的值
console.log(“价值”,项目[a]);
}
你可以尝试使用lodash-一个现代的JavaScript实用程序库,提供模块化,性能和额外的js来快速对象迭代
var users = {
'fred': {
'user': 'fred',
'age': 40
},
'pebbles': {
'user': 'pebbles',
'age': 1
}
};
_.mapValues(users, function(o) {
return o.age;
});
// => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)
// The `_.property` iteratee shorthand.
console.log(_.mapValues(users, 'age')); // returns age property & value
console.log(_.mapValues(users, 'user')); // returns user property & value
console.log(_.mapValues(users)); // returns all objects
// => { 'fred': 40, 'pebbles': 1 } (iteration order is not guaranteed)
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash-compat/3.10.2/lodash.js"></script>