{category}

JavaScript - Object

Object.freeze()

オブジェクト・フリーズ(組み込みオブジェクト

意味 オブジェクトの固定


Object.freeze()とは?

`Object.freeze()`メソッドは、オブジェクトを固定し、そのプロパティを追加、削除、または変更することを防ぐために使用されます。

Object.freeze()の具体的な使い方

ボタンクリックでオブジェクトを凍結する例

<button onclick='freezeExample()'>Freeze Example</button>
<script>
function freezeExample() {
  const obj = { prop: 42 };
  Object.freeze(obj);
  try {
    obj.prop = 33;
  } catch (e) {
    alert('エラー: ' + e.message);
  }
  alert('現在の値: ' + obj.prop);
}
</script>

この例では、`obj`オブジェクトを固定してから、そのプロパティを変更しようとするとエラーが発生し、現在の値がアラートで表示されます。

Object.freeze()の基本的な使用法

const obj = {
  prop1: 'value1',
  prop2: 'value2'
};

Object.freeze(obj);

// プロパティの変更を試みる
obj.prop1 = 'new value';

// 新しいプロパティの追加を試みる
obj.prop3 = 'value3';

// プロパティの削除を試みる
delete obj.prop2;

console.log(obj);

👇出力結果

{ prop1: 'value1', prop2: 'value2' }

この例では、オブジェクトをフリーズした後、プロパティの変更、追加、削除を試みています。フリーズされたオブジェクトは変更されないことがわかります。

Object.freeze()に関するよくある質問

Q. Object.freeze()の目的は?
A. Object.freeze()の主な目的は、オブジェクトを不変(イミュータブル)にすることです。これにより、オブジェクトのプロパティの追加、削除、変更を防ぎ、オブジェクトの構造を保護します。
Q. 凍結後のオブジェクトは変更可能?
A. いいえ、Object.freeze()で凍結されたオブジェクトは変更できません。プロパティの追加、削除、既存の値の変更はできません。ただし、ネストされたオブジェクトは別途凍結する必要があります。
Q. freeze()とconst宣言の違いは?
A. constはコンテナ自体の再代入を防ぎますが、オブジェクトの内容は変更可能です。一方、Object.freeze()はオブジェクトの内容を変更不可にしますが、変数自体の再代入は防げません。

Object.freeze()が学べる書籍の紹介

「プログラミング単語帳」を使って、プログラミングの単語を英単語のように学習してみませんか?
プログラミング単語帳には、JavaScriptのObject.freeze()やObject.assign()、Date.now()、Math.random()、などのような実務でよく使われる単語が数百以上収録されています。
この書籍には、プログラミングの単語の意味や読み方、単語の使い方がわかる例文などが掲載されており、いつでもどこでもプログラミングの学習ができます。

よく使われる単語にだけ絞って学習することができるので、効率的にプログラミングが学習できます。

1日5分の暗記でプログラミンが身に付く!プログラミング単語帳 公式ストアで発売中!

HTML編、CSS編、JavaScript編、PHP編、Ruby編、その他単語編の6シリーズ分が公式ストアにて販売中です。気になった方はぜひ購入してみてください。


JavaScriptを学べる「プログラミング単語帳」アプリ

プログラミング単語帳がアプリになりました!JavaScriptはもちろん、10種類のプログラミング言語の中から、よく使われる単語をスマホで学習できます。

収録単語は2,000単語以上!
現在は、HTML、CSS、JavaScirpt、PHP、Laravel、Ruby、Python、MySQL、Linux、など10カテゴリーの単語帳が1つのアプリに収録されています。

いつでも、どこでも、隙間時間を有効活用して、プログラミングを効率的に学べるので、ぜひダウンロードしてみてください。

2024年7月アップデート情報:「Laravel」カテゴリーが追加されましました!

2024年8月アップデート情報:「MySQL」「Linux」カテゴリーが追加されましました!


関連するそのほかの単語

Object.assign()

オブジェクト結合・コピー

種類: Object

Date.now()

現在のミリ秒を取得

種類: Date

Math.random()

0-1の乱数生成

種類: Math

WebGL

3Dグラフィックス描画API

種類: グラフィックスとアニメーション

=

代入

種類: 宣言・代入