这里的键可能是动态的。所以我只需要获取值而不考虑键。
var test = []
var arrayObj = [
{
"abc": {
"value": "1"
},
"def": {
"value": "TERN"
},
"aec": {
"value": "SASU"
},
"rtg": {
"value": "FI"
},
"ttyg": {
"value": "9"
},
"yty": {
"value": "uyMFG"
}
},
{
"abc": {
"value": "1"
},
"def": {
"value": "EXT"
},
"aec": {
"value": "SAM"
},
"rtg": {
"value": "FINISH"
},
"ttyg": {
"value": "5"
},
"yty": {
"value": "MFG"
}
}]
function printValues(obj) {
for (var key in obj) {
if (typeof obj[key] === "object") {
printValues(obj[key]);
} else {
test.push(obj[key])
}
}
}
printValues(arrayObj);
console.log(test);
我得到这个
["1","TERN","SASU","FI","9","uyMFG","1","EXT","SAM","FINISH","5","MFG"]
但是,我需要得到如下输出
[["1","TERN","SASU","FI","9","uyMFG"],["1","EXT","SAM","FINISH","5","MFG"]]
我是否以正确的方式做事,或者我可以得到比我的方法更好的方法? 请建议我如何实现这一目标。我不知道我哪里出错了。
答案 0 :(得分:1)
如果您不是特别需要递归函数,您可以使用一些 Object
和 Array
方法来实现。
var arrayObj=[{abc:{value:"1"},def:{value:"TERN"},aec:{value:"SASU"},rtg:{value:"FI"},ttyg:{value:"9"},yty:{value:"uyMFG"}},{abc:{value:"1"},def:{value:"EXT"},aec:{value:"SAM"},rtg:{value:"FINISH"},ttyg:{value:"5"},yty:{value:"MFG"}}];
const output = arrayObj.map(obj => {
return Object.values(obj).map(({value}) => value)
})
console.log(output);
答案 1 :(得分:1)
以最简单的形式,您可以映射数组并返回 Object.values() 的映射。
这假设深度已知(如示例所示)并且 value
属性一致
const res = arrayObj.map(e => Object.values(e).map(o => o.value))
console.log(res)
<script>
var arrayObj=[{abc:{value:"1"},def:{value:"TERN"},aec:{value:"SASU"},rtg:{value:"FI"},ttyg:{value:"9"},yty:{value:"uyMFG"}},{abc:{value:"1"},def:{value:"EXT"},aec:{value:"SAM"},rtg:{value:"FINISH"},ttyg:{value:"5"},yty:{value:"MFG"}}];
</script>
答案 2 :(得分:0)
您不应在数组上使用 for..in
。
在数组、字符串等可迭代对象上使用 for..of
在对象上使用 for..in
。
var arrayObj = [
{
abc: { value: "1" },
def: { value: "TERN" },
aec: { value: "SASU" },
rtg: { value: "FI" },
ttyg: { value: "9" },
yty: { value: "uyMFG" },
},
{
abc: { value: "1" },
def: { value: "EXT" },
aec: { value: "SAM" },
rtg: { value: "FINISH" },
ttyg: { value: "5" },
yty: { value: "MFG" },
},
];
var test = [];
function printValues(arr) {
for (var obj of arr) {
const temp = [];
for (let key in obj) {
temp.push(obj[key].value);
}
test.push(temp);
}
}
printValues(arrayObj);
console.log(test);