ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript オブジェクト内のネストされたキーの存在を効率的に確認するにはどうすればよいですか?

JavaScript オブジェクト内のネストされたキーの存在を効率的に確認するにはどうすればよいですか?

Linda Hamilton
リリース: 2025-01-01 07:09:11
オリジナル
653 人が閲覧しました

How Can I Efficiently Check for the Existence of Nested Keys in a JavaScript Object?

ネストされた JavaScript オブジェクト キーの存在のテスト

深くネストされた JavaScript オブジェクトを検査する場合、特定のキーの存在を確認することが困難になる場合があります。標準的なアプローチには逐次チェックが含まれますが、これは面倒でエラーが発生しやすい可能性があります。

より堅牢な解決策は、オブジェクト構造を段階的にナビゲートする再帰関数を利用することです。例:

function checkNested(obj, ...levels) {
  for (var i = 0; i < levels.length; i++) {
    if (!obj || !obj.hasOwnProperty(levels[i])) {
      return false;
    }
    obj = obj[levels[i]];
  }
  return true;
}
ログイン後にコピー

この関数は、オブジェクトと任意の数のレベルを引数として受け取ります。レベルを反復処理して、対応する各キーが存在するかどうかを確認し、オブジェクト ポインターをインクリメントします。キーが欠落している場合、またはオブジェクトが未定義の場合は false を返します。それ以外の場合は true を返します。

使用例:

const test = { level1: { level2: { level3: 'level3' } } };

checkNested(test, 'level1', 'level2', 'level3'); // true
checkNested(test, 'level1', 'level2', 'foo'); // false
ログイン後にコピー

または、ES6 を利用して再帰関数を簡素化することもできます:

function checkNested(obj, level, ...rest) {
  if (obj === undefined) return false;
  if (rest.length == 0 && obj.hasOwnProperty(level)) return true;
  return checkNested(obj[level], ...rest);
}
ログイン後にコピー

ただし、深くネストされたプロパティの値の場合は、1 行の関数を使用できます:

function getNested(obj, ...args) {
  return args.reduce((obj, level) => obj && obj[level], obj);
}

console.log(getNested(test, 'level1', 'level2', 'level3')); // 'level3'
console.log(getNested(test, 'level1', 'level2', 'level3', 'length')); // 6
console.log(getNested(test, 'level1', 'level2', 'foo')); // undefined
ログイン後にコピー

以上がJavaScript オブジェクト内のネストされたキーの存在を効率的に確認するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート