序文これは 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); // 未定義 ここではリテラル初期化が使用されているため、性別属性が私に割り当てられても無意味であり、属性にアクセスすることはできません。 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 をよろしくお願いいたします。 |
>>: MySQLデータベースのbinlogクリーンアップコマンドの詳細な説明
この記事では、参考までに、簡単な計算機を実装するためのJavaScriptの具体的なコードを紹介しま...
ハッシュモード(デフォルト)動作原理:ウェブページのハッシュ値の変化を監視する—> onhas...
前回の記事では、beforeとafterの擬似要素を使用してMaterial Designスタイルの...
目次1. 現在のシステムにMySQLがインストールされているかどうかを確認する2. インストールされ...
MYSQLバージョン:MySQL Community Server 5.7.17、インストール不要版...
目次JVM クラスローダーTomcat クラスローダークラスを検索ロードクラスクラスをロードしようと...
MySQL解凍版とNavicatデータベース操作ツールのインストールは、以下のとおりです。 1. M...
Linux 上の LibreOffice で Microsoft ドキュメントを開くと、フォントが少...
公式サイトからインストールパッケージをダウンロードします: mysql-8.0.19-linux-g...
ここで、アンカー ポイントを制御するいくつかの状況をまとめてみましょう。 1. 同じページ <...
この記事では、主にリスト構造を使用して水平ナビゲーション構造を設定する 2 つの方法を紹介します。こ...
順序なしリストでは、順序なしリストのシンボルは各リストの前に表示されるドットです。順序付きリスト o...
実行環境、Idea2020バージョン、Tomcat10、実行時にTomcat CatalinaLog...
<スタイル タイプ="text/css">コードをコピーコードは次の...
目次ネットワーク情報ホスト名を変更するDNSドメイン名解決ネットワーク関連コマンドファイアウォール暗...