ホームページ ウェブフロントエンド jsチュートリアル Pure JavaScript で JSON オブジェクト ツリーを効率的に走査するにはどうすればよいですか?

Pure JavaScript で JSON オブジェクト ツリーを効率的に走査するにはどうすればよいですか?

Nov 30, 2024 pm 05:34 PM

How Can I Efficiently Traverse a JSON Object Tree in Pure JavaScript?

外部ライブラリを使用しない JavaScript での JSON オブジェクト ツリーの走査

複雑なデータ構造を扱う場合、JSON オブジェクト ツリーの走査は一般的なタスクになる可能性があります。 JavaScript には、オブジェクトを操作するための関数の豊富なライブラリが用意されていますが、オブジェクト ツリーを走査するための専用のライブラリはありません。これは簡単な作業のように思えるかもしれませんが、多くの場合、車輪の再発明につながります。

ツリーを走査するためのさまざまな DOM ベースのアプローチを提供する XML とは異なり、JavaScript には JSON オブジェクトに対する同様のメカニズムがありません。この記事では、純粋な JavaScript 関数を使用して JSON オブジェクト ツリーを走査するための効率的かつ簡単なソリューションを紹介します。

カスタム再帰走査関数

この解決策には、JSON オブジェクト ツリーを走査するカスタム再帰関数の作成が含まれます。オブジェクトツリー。関数 traverse() は 2 つのパラメータを取ります:

  • o: トラバースする JSON オブジェクト
  • func: ツリー内の各ノードを処理するコールバック関数

関数は、オブジェクト内の各プロパティとその値を反復処理します。プロパティと値のペアごとに、コールバック関数を呼び出してデータを処理します。値が別のオブジェクトであり、null ではない場合、関数はそれ自体を再帰的に呼び出して子オブジェクトを走査します。

使用例

使用法を示すために、次のことを考えてみましょう。 JSON オブジェクト:

var o = { 
    foo:"bar",
    arr:[1,2,3],
    subo: {
        foo2:"bar2"
    }
};
ログイン後にコピー

それぞれのキーと値を記録する process() 関数を定義します。これで、次の出力が得られます。出力にはサブオブジェクトのキーが含まれますが、そのプロパティは含まれません。これは、traverse() 関数がサブオブジェクトを再帰的に走査しないためです。全深度のトラバーサルを実現するには、それに応じてコードを変更する必要があります。

以上がPure JavaScript で JSON オブジェクト ツリーを効率的に走査するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

JavaScriptの文字列文字を交換します JavaScriptの文字列文字を交換します Mar 11, 2025 am 12:07 AM

JavaScriptの文字列文字を交換します

カスタムGoogle検索APIセットアップチュートリアル カスタムGoogle検索APIセットアップチュートリアル Mar 04, 2025 am 01:06 AM

カスタムGoogle検索APIセットアップチュートリアル

例JSONファイルの例 例JSONファイルの例 Mar 03, 2025 am 12:35 AM

例JSONファイルの例

8見事なjQueryページレイアウトプラグイン 8見事なjQueryページレイアウトプラグイン Mar 06, 2025 am 12:48 AM

8見事なjQueryページレイアウトプラグイン

10 jQuery構文蛍光物 10 jQuery構文蛍光物 Mar 02, 2025 am 12:32 AM

10 jQuery構文蛍光物

' this' JavaScriptで? ' this' JavaScriptで? Mar 04, 2025 am 01:15 AM

' this' JavaScriptで?

独自のAjax Webアプリケーションを構築します 独自のAjax Webアプリケーションを構築します Mar 09, 2025 am 12:11 AM

独自のAjax Webアプリケーションを構築します

10 JavaScript&JQuery MVCチュートリアル 10 JavaScript&JQuery MVCチュートリアル Mar 02, 2025 am 01:16 AM

10 JavaScript&JQuery MVCチュートリアル

See all articles