オブジェクトが深く凍結されているかどうかを確認する

Beginner

This tutorial is from open-source community. Access the source code

はじめに

この実験では、JavaScript でオブジェクトが深く凍結されているかどうかを確認する方法を学びます。この実験では、Object.isFrozen() を使用してオブジェクトが凍結されているかどうかを判断する再帰関数と、深い凍結を確認するために Object.keys()Array.prototype.every() を使用します。この実験が終了するまでに、JavaScript でオブジェクトの深い凍結状態を判断する方法をより深く理解するようになります。

オブジェクトが深く凍結されているかどうかを確認する方法

JavaScript でオブジェクトが深く凍結されているかどうかを確認するには、次の手順を使用します。

  1. ターミナル/SSH を開き、コーディングを練習するために node と入力します。
  2. 再帰を使用して、オブジェクトのすべてのプロパティが深く凍結されているかどうかを確認します。
  3. 与えられたオブジェクトに Object.isFrozen() を使用して、それが浅く凍結されているかどうかを確認します。
  4. Object.keys() を使用してオブジェクトのすべてのプロパティを取得し、Array.prototype.every() を使用してすべてのキーが深く凍結されたオブジェクトまたは非オブジェクト値であることを確認します。

オブジェクトが深く凍結されているかどうかを確認するためのコード スニペットの例を次に示します。

const isDeepFrozen = (obj) =>
  Object.isFrozen(obj) &&
  Object.keys(obj).every(
    (prop) => typeof obj[prop] !== "object" || isDeepFrozen(obj[prop])
  );

次のように、isDeepFrozen 関数を使用してオブジェクトが深く凍結されているかどうかを確認できます。

const x = Object.freeze({ a: 1 });
const y = Object.freeze({ b: { c: 2 } });
isDeepFrozen(x); // true
isDeepFrozen(y); // false

まとめ

おめでとうございます!オブジェクトが深く凍結されているかどうかを確認する実験を完了しました。スキルを向上させるために、LabEx でさらに多くの実験を行って練習できます。