无论键需要将值推入数组

时间:2021-06-30 23:12:25

标签: javascript jquery

这里的键可能是动态的。所以我只需要获取值而不考虑键。

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"]]

我是否以正确的方式做事,或者我可以得到比我的方法更好的方法? 请建议我如何实现这一目标。我不知道我哪里出错了。

3 个答案:

答案 0 :(得分:1)

如果您不是特别需要递归函数,您可以使用一些 ObjectArray 方法来实现。

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);