ホームページ > ウェブフロントエンド > フロントエンドQ&A > javascriptはjsonにキーが存在するかどうかを判断します

javascriptはjsonにキーが存在するかどうかを判断します

王林
リリース: 2023-05-10 09:39:06
オリジナル
5635 人が閲覧しました

JavaScript は、JSON データ型をサポートする広く使用されているスクリプト言語です。 JSON データを処理する場合、JSON オブジェクトに特定のキーが存在するかどうかを確認する必要がある場合があります。この記事では、JavaScript を使用して JSON にキーが存在するかどうかを判断する方法とテクニックを紹介します。

1. JavaScript の JSON データ型

JSON (JavaScript Object Notation) は、データ交換に使用される軽量のデータ形式です。 JavaScript には、オブジェクト、配列、文​​字列という 3 つの JSON データ型があります。このうち、オブジェクトはキーと値のペアのコレクションであり、キーは文字列であり、値は任意の JSON データ型にすることができます。オブジェクトは次のように定義されます。

var obj = {
    key1: "value1",
    key2: 2,
    key3: [1, 2, 3],
    key4: {
        subkey1: "subvalue1",
        subkey2: "subvalue2"
    }
};
ログイン後にコピー

ここで、「key1」から「key4」はオブジェクトの属性名であり、ドット表記または角括弧表記を使用してアクセスできます (例: obj.key1)。 obj["key1"] は両方とも属性値を取得できます。

2. JSON オブジェクトにキーが存在するかどうかを判断するメソッド

  1. in 演算子

in 演算子を使用して、オブジェクトが JSON オブジェクトに存在するかどうかを判断できます。

key in object
ログイン後にコピー

このうち、key は属性名、object はオブジェクトです。オブジェクトにこの属性がある場合は true を返し、そうでない場合は false を返します。

たとえば、オブジェクトに「key1」という名前のプロパティがあるかどうかを判断するには:

var obj = {
    key1: "value1",
    key2: "value2"
};
if ("key1" in obj) {
    console.log("obj有key1属性");
} else {
    console.log("obj没有key1属性");
}
ログイン後にコピー
  1. hasOwnProperty メソッド

hasOwnProperty メソッドを使用して判断できます。オブジェクトかどうか 独自の属性があり、構文は次のとおりです。

object.hasOwnProperty(key)
ログイン後にコピー

このうち、key は属性名、object はオブジェクトです。オブジェクトにこの属性がある場合は true を返し、そうでない場合は false を返します。

たとえば、オブジェクトに「key1」という名前のプロパティがあるかどうかを確認するには、次のようにします。

var obj = {
    key1: "value1",
    key2: "value2"
};
if (obj.hasOwnProperty("key1")) {
    console.log("obj有key1属性");
} else {
    console.log("obj没有key1属性");
}
ログイン後にコピー
  1. typeof および unknown

JavaScript で、次のようにアクセスします。 unknown プロパティが存在する場合は、unknown が返されます。したがって、typeof と unknown を使用して、属性が存在するかどうかを確認できます。構文は次のとおりです:

typeof object.key !== "undefined"
ログイン後にコピー

ここで、key は属性名、object はオブジェクトです。オブジェクトにこの属性がある場合は true を返し、そうでない場合は false を返します。

たとえば、オブジェクトに「key1」という名前の属性があるかどうかを判断します:

var obj = {
    key1: "value1",
    key2: "value2"
};
if (typeof obj.key1 !== "undefined") {
    console.log("obj有key1属性");
} else {
    console.log("obj没有key1属性");
}
ログイン後にコピー

3. 結論

JavaScript では、JSON オブジェクトに特定のキーがあるかどうかを判断します。メソッドは、in 演算子、hasOwnProperty メソッド、typeof、unknown の 3 つです。どの方法を使用するかは、使用シナリオや個人の習慣によって異なります。

in 演算子と hasOwnProperty メソッドを使用する場合は、継承されたプロパティの問題に注意する必要があることに注意してください。オブジェクトがそれ自体のプロパティではなく、プロトタイプ チェーン内で見つかったプロパティである場合、in 演算子と hasOwnProperty メソッドの両方が false を返します。したがって、これら 2 つのメソッドを使用する場合は、Object.prototype.hasOwnProperty.call(obj, key) を組み合わせて使用​​して、プロパティがオブジェクト自体のプロパティであるかどうかを判断できます。

4. 例

次は、3 つのメソッドを使用して、特定のキーを持つオブジェクトが存在するかどうかを確認する方法を示す完全な例です。では、JSON にキーが存在するかどうかを判断するための 3 つの方法の典型的な実際のアプリケーションを確認できます。実際のプロジェクトのニーズに応じてさまざまな方法を選択し、コードを最適化しながら継続的に改善し、深く学習することができます。

以上がjavascriptはjsonにキーが存在するかどうかを判断しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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