を使用して、オブジェクトの1つの配列を1つのネストされたオブジェクト構造に変換しようとしていますJavascript
が、期待どおりの結果が得られません。以下に私のコードを説明しています。
let data = [
{
"hop_no": 1,
"jumphost_id": "jumphost1"
},
{
"hop_no": 2,
"jumphost_id": "jumphost2"
},
{
"hop_no": 3,
"jumphost_id": "another-jumphost"
},
{
"hop_no": 4,
"jumphost_id": "last-jumphost"
}
]
let result ='';
for(let i = 0; i< data.length; i++) {
const index = i+1;
const obj = data.find(o => o.name === index);
if(result === '' && !result['host-id']) {
result = {
"host-id": obj.jumphost_id,
"next-hop":{}
}
}else{
if(result['next-hop'] === '') {
result['next-hop'] = obj.jumphost_id
}
}
}
ここにオブジェクトの配列が示さi.e- data
れ、予想される構造が以下に示されています。
以下の期待される結果。
{
"host-id": "jumphost1",
"next-hop": {
"host-id": "jumphost2",
"next-hop": {
"host-id": "another-jumphost",
"next-hop": {
"host-id": "last-jumphost",
}
}
}
}
ここでの条件は"hop_no": 1
、それぞれのjumphost_id
値が最初のキーに割り当てられhost-id
、最初のキーになるときです。その後、ネストされたオブジェクト構造が値の昇順で形成されhop_no
、それぞれのjumphost_id
値がキーに割り当てられnext-hop
ます。誰かがJavascriptのみを使用してこの構造を設計するのを手伝ってもらえますか?
reduce
これは次の関数で実行できます。
let data = [{
"hop_no": 1,
"jumphost_id": "jumphost1",
ip: "",
port: 22,
user: "",
password: "",
"device-type": "linux"
},
{
"hop_no": 2,
"jumphost_id": "jumphost2",
ip: "",
port: 22,
user: "",
password: "",
"device-type": "linux"
},
{
"hop_no": 3,
"jumphost_id": "another-jumphost",
ip: "",
port: 22,
user: "",
password: "",
"device-type": "linux"
},
{
"hop_no": 4,
"jumphost_id": "last-jumphost",
ip: "",
port: 22,
user: "",
password: "",
"device-type": "linux"
}
]
let result = data.sort((a, b) => b.hop_no - a.hop_no).reduce((prev, curr, i, array) => {
let { hop_no, jumphost_id, ...rest } = curr
return {
'host-id': jumphost_id,
...rest,
...(i > 0 ? {'next-hop': { ...prev }} : {}),
}
}, {})
console.log(result)
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加