ネストされた JavaScript オブジェクトの反復
ネストされた JavaScript オブジェクトの反復は、特にプロパティに基づいて特定のオブジェクトを取得する必要がある場合に困難になることがあります。価値。次の例を考えてみましょう:
var cars = {
label: 'Autos',
subs: [
{
label: 'SUVs',
subs: []
},
{
label: 'Trucks',
subs: [
{
label: '2 Wheel Drive',
subs: []
},
{
label: '4 Wheel Drive',
subs: [
{
label: 'Ford',
subs: []
},
{
label: 'Chevrolet',
subs: []
}
]
}
]
},
{
label: 'Sedan',
subs: []
}
]
};
「Ford」ブランドのオブジェクトを取得したい場合は、再帰的アプローチを使用できます:
const iterate = (obj, identifier) => {
for (let key in obj) {
if (obj[key]['label'] === identifier) {
return obj[key];
}
if (typeof obj[key] === 'object' && obj[key] !== null) {
const result = iterate(obj[key], identifier);
if (result) {
return result;
}
}
}
return null;
};
const fordObject = iterate(cars, 'Ford');
この例では、iterate 関数は、検索するオブジェクトと識別子文字列の 2 つのパラメーターを取ります。オブジェクトのプロパティを反復処理して、ラベル プロパティが識別子と一致するかどうかを確認します。そうでない場合は、プロパティが別のオブジェクトであるかどうかをチェックし、反復を続行します。一致するオブジェクトが見つからない場合は、null を返します。
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3