ECMAScriptにおけるプリミティブ値と参照値の詳しい説明

ECMAScriptにおけるプリミティブ値と参照値の詳しい説明

序文

これは JavaScript の非常に基本的な知識ポイントであるはずですが、多くの友人は面接中に簡単に触れただけで、それについて何も知らないようです。ここでは、以前のメモと合わせて、プリミティブ値と参照値の関連知識を簡単に紹介します。それでは始めましょう。

ECMAScript では、変数にはプリミティブ値または参照値の 2 つのデータ型を含めることができると規定されています。プリミティブ値は最も単純なデータ構造ですが、参照値は複数の値で構成されるオブジェクトです。

プリミティブ値は、Undefined、Null、Boolean、Number、String、Symbol の計 6 種類あります。プリミティブ値を操作するということは、格納変数内の実際の値を操作することを意味します。

参照値は、メモリに格納されているオブジェクトです。JavaScript はメモリ位置に直接アクセスできないため、オブジェクトが配置されているメモリ空間を直接操作することはできません。オブジェクトを操作する場合、実際にはオブジェクト自体ではなく、オブジェクトの参照を操作しています。

動的プロパティとは何ですか?

動的プロパティとは、参照値が作成された後、そのプロパティとメソッドを動的に追加、変更、削除できることを意味します。例:

obj = new Object();
obj.name = "サム";

console.log(obj.name); // "サム"

説明: まず、参照値オブジェクトが作成され、変数 obj に格納されます。次に、名前属性が値 "Sam" で obj に割り当てられます。このプロパティが変更/削除されない限り、このプロパティを直接印刷したりアクセスしたりできます。

プリミティブ値には属性を持たせることはできませんが、属性操作を実行してもエラーは報告されません。例:

let me = "Sam";
me.sex = "男性";

console.log(me.sex); // 未定義

ここではリテラル初期化が使用されているため、性別属性が私に割り当てられても無意味であり、属性にアクセスすることはできません。
new キーワードを使用してプリミティブ値を初期化すると、JavaScript は Object インスタンスを作成します。例:

let me = new String("Sam");
me.sex = "男性";

console.log(me.sex); // "男性"

値のコピー

プリミティブ値と参照値は、変数を介してコピーされる場合にも異なります。プリミティブ値は新しい変数にコピーされますが、参照値は実際には値へのポインタをコピーします。例:

名前を "Sam" にします。
myName = 名前とします。

console.log(myName); // "サム"

myName が name に初期化されると、「Sam」も myName にコピーされますが、これは name とは独立しており、互いに干渉しません。myName は name のコピーであると理解できます。

参照値のコピーは、実際にはヒープ メモリ内のオブジェクトを指すポインターをコピーします。コピーされた変数に対する属性操作は、実際にはコピーされたオブジェクトに対する操作です。2 つの変数は実際には同じオブジェクトを参照します。例:

let me = new Object();
あなた=私になります。

me.name = "サム";

console.log(you.name); // "サム"

値の種類を決定する

変数の型を決定するために typeof をよく使用します。これはプリミティブ値の型を決定するのに便利ですが、参照値と null の場合、typeof はオブジェクトを返すため、参照値を決定するのにはあまり役立ちません。

通常、これがどのようなタイプのオブジェクトであるかを正確に知る必要があるため、instanceof 演算子を使用します。構文は次のとおりです。

結果 = 変数インスタンスコンストラクタ

instanceof はブール値を返します。例:

console.log(person オブジェクトのインスタンス);  
// 変数 person はオブジェクトですか?

console.log(色のインスタンス配列);   
// 変数 colors は配列ですか?

console.log(パターンインスタンスRegExp); 
// 変数パターンは正規表現ですか?

プリミティブ値に対して instanceof を使用すると、プリミティブ値はオブジェクトではないため、常に false が返されます。

要約する

ECMAScript におけるオリジナル値と参照値についての記事はこれで終了です。ECMAScript におけるオリジナル値と参照値についてさらに詳しく知りたい方は、123WORDPRESS.COM の過去記事を検索するか、引き続き以下の関連記事を閲覧してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

<<:  Linux のリンク解除機能とファイルの削除方法

>>:  MySQLデータベースのbinlogクリーンアップコマンドの詳細な説明

推薦する

CSS3 を使用した背景ぼかし効果の 3 つの例

導入から始めず、いきなり本題に入りましょう。通常の背景ぼかし効果は次のとおりです。 プロパティを使用...

役に立つメタ設定方法(必読)

<meta name="viewport" content="...

Vue の基本入門: Vuex のインストールと使用

目次1. vuexとは何か2. インストールと導入3. vuexの使用4. プロセスの紹介5. 突然...

Windows 10 での MySQL 5.7.21 インストーラのインストール グラフィック チュートリアル

MySQLをインストールしてメモしておきます。うまくインストールできるか分かりませんが、試してみます...

測定画像HTTPリクエスト

一般的なブラウザでテスト ページを開き、Fiddler で http リクエストを表示してください。...

VUE ユニアプリコア知識の簡単な紹介

目次仕様a. ページファイルはVueの単一ファイルコンポーネント仕様に準拠しています。 b. コンポ...

MySQL InnoDB ロック メカニズムの詳細な例

1. InnoDBのロック機構InnoDB ストレージ エンジンは、行レベルのロックとトランザクショ...

Vue-Routerのルート設定の詳しい説明

目次導入ルート内のオブジェクト属性パス: 文字列コンポーネント: コンポーネント | () =>...

Vue2.0は適応解像度を実装する

この記事では、適応解像度を実現するためのVue2.0の具体的なコードを参考までに紹介します。具体的な...

mysql 更新ケース更新フィールド値が固定されていない操作

特定のデータの一括更新処理において、特定のステータスが固定値に更新されるなど、更新するフィールドの値...

MySQLで現在の時間間隔の前日のデータをクエリする

1. 背景実際のプロジェクトでは、分散スケジュールされたタスク実行の状況に遭遇することがあります。ス...

Vue+Openlayer で select を使用して要素を選択する実装コード

効果画像: 実装コード: <テンプレート> <div id="map&q...

HTML のブロックレベル要素と行レベル要素、特殊文字、ネスト規則

基本的な HTML Web ページ タグのネスト ルールを紹介する場合、最初に説明する必要があるのは...

SSL を実装するために nginx を設定する方法の例

環境説明サーバーシステム: Ubuntu 18.04 64ビットnginx: 1.14この記事では主...

Vueプロジェクトでのトークン検証ログイン(フロントエンド部分)

この記事の例では、Vueプロジェクトでのトークン検証ログインの具体的なコードを参考までに共有していま...